晨鸟科技
标题:
解释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' r
string.Empty不分配存储空间
8 [) w4 n9 k4 d |$ ~
""分配一个长度为空的存储空间
' ^0 X2 \, \- {# u y$ G
所以一般用string.Empty
9 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 b
string 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