晨鸟科技

标题: 解释SqlServer中null和''的区别 [打印本页]

作者: Star    时间: 2010-7-30 19:49
标题: 解释SqlServer中null和''的区别
本帖最后由 Star 于 2011-6-9 21:04 编辑
# G0 o8 @# O( C( w" d. H( ^6 c! r& e& S; t* i" H
详细解释SqlServer中对于空字符的处理, r: H1 B+ Q2 W, ?
一次存储过程中,以null作为if判断条件,存储过程执行的结果如:
$ X/ w' i6 d' y. y7 P1 `" o4 ?[attach]52[/attach]
/ K1 u' o8 _/ k0 e7 U而将所有的null替换成'',之后,执行结果如:
6 W8 e  J, G) N[attach]51[/attach]+ H4 J- }' n6 R8 f
! x* @; u: T' P& ~& s7 J: S
请帮忙解释
作者: Star    时间: 2010-7-30 20:02
【String.Empty,NULL和""的区别】1 N3 V6 ^6 }# p+ S4 E

9 [4 {, K( W3 S' rstring.Empty不分配存储空间
8 [) w4 n9 k4 d  |$ ~      ""分配一个长度为空的存储空间   
' ^0 X2 \, \- {# u  y$ G      所以一般用string.Empty9 V: p! }$ ?  f9 p& M8 @- X, ^

7 P7 g* v" y% o5 B+ d/ N+ s9 j为了以后跨平台,还是用string.empty( L2 ~2 A. r. U- N4 L

  |! A8 e3 g7 `1 o2 P. |3 y在 C# 中,大多数情况下 "" 和 string.Empty 可以互换使用。比如:
$ d& ?, J9 ^5 y$ k/ r; q. R6 J( P! r$ Q: G. x: x- B
string s = "";
" e5 K( N0 N$ Y+ K4 P. n0 ^. @( y6 bstring s2 = string.Empty;
# v9 ^/ G3 f. x3 |
# y9 q* w  D/ f* T, B# L1 ~if (s == string.Empty) {
2 H0 o$ \, f* f9 Q, x3 r9 s; ~2 o0 X  // 5 q% }, J5 P4 `
}# q; c- u9 I  i$ b/ I
if语句成立
' c' ^4 d. @; i3 a$ H2 Z; r, J7 ]2 d& m* y# {' {% Z9 z

: E2 j( m( g8 W. D  A3 ^* ~' _& l判定为空字符串的几种写法,按照性能从高到低的顺序是:/ ~, z; A! g7 z6 Q6 K
& c+ W- K, j4 W* v4 ~1 A
s.Length == 0      优于 s == string.Empty      优于 s == "" . m7 g$ \3 o( `
' d, R' T5 b- j8 y7 a5 h
& U  ^5 ~6 [) i, W( J' G
关于String.Empty和Null的问题是这样的,这两个都是表示空字符串,其中有一个重点是string str1= String.Empty和 string str2=null 的区别,这样定义后,str1是一个空字符串,空字符串是一个特殊的字符串,只不过这个字符串的值为空,在内存中是有准确的指向的,string str2=null,这样定义后,只是定义了一个string 类的引用,str2并没有指向任何地方,在使用前如果不实例化的话,都将报错。textBox1.Text的值为零长度字符串 ""。




欢迎光临 晨鸟科技 (http://www.chenniao.com/cprofessor/) Powered by Discuz! X3.2