晨鸟科技

 找回密码
 注册
搜索
查看: 14191|回复: 1
打印 上一主题 下一主题

解释SqlServer中null和''的区别

[复制链接]
跳转到指定楼层
楼主
发表于 2010-7-30 19:49:53 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
10金钱
本帖最后由 Star 于 2011-6-9 21:04 编辑
7 Q4 P; s9 l: W9 y5 _) h- k
4 H" C* A2 v. }6 O0 q3 \详细解释SqlServer中对于空字符的处理7 W+ N! }& N$ F% B! c0 V
一次存储过程中,以null作为if判断条件,存储过程执行的结果如:
2 q; o( L5 ]+ x+ T  p6 U( `/ `! w3 c
而将所有的null替换成'',之后,执行结果如:- z: q- V8 v' W9 N
5 [4 \6 A# {; a4 T1 L
* v( Q9 B) w. G5 m( Z  ?
请帮忙解释

附件: 您需要 登录 才可以下载或查看,没有帐号?注册
沙发
 楼主| 发表于 2010-7-30 20:02:54 | 只看该作者
【String.Empty,NULL和""的区别】
: p/ E  ?; ?2 U, D
5 H  ~/ w2 T2 d- O8 P6 R+ a& lstring.Empty不分配存储空间9 ^2 R- V" H  m( k' E" ?/ q, u
      ""分配一个长度为空的存储空间   
" v3 R& r  R- V3 i      所以一般用string.Empty
5 S' }2 Q0 v% r3 i; L8 r3 S' g; o/ R3 j
为了以后跨平台,还是用string.empty* S. n& |& V( t1 O" q% z* s
4 ?/ S% }. E/ x
在 C# 中,大多数情况下 "" 和 string.Empty 可以互换使用。比如:
/ G0 b5 R8 g" @; r7 M- m! s* z- n( c; d! t- t1 m7 {4 ~
string s = "";
* F, N9 ~* J* @2 r8 Y/ S( B$ Rstring s2 = string.Empty;
. i% f4 e; T0 w) D. L* s$ S2 A& K. l
if (s == string.Empty) {
0 T7 P; x5 U' f" s  // : h# ?4 I' t- g1 W* |3 z8 r9 R
}. n! b% l! h, X$ ]: j9 k3 J
if语句成立 - N$ |7 b% e0 z( a4 F
1 G! o  Y" @: Y( }4 h2 {& f
+ b, \& g: ]3 x# f8 X8 k
判定为空字符串的几种写法,按照性能从高到低的顺序是:+ T# M6 o- E6 [3 U& V

  ^. `' O3 l$ B+ i3 l) Es.Length == 0      优于 s == string.Empty      优于 s == "" * ^/ V* V: y6 [
" w+ d% `$ s* N! J2 p# d; ]: P( V# ^
% S2 C# O1 ?1 \* V
关于String.Empty和Null的问题是这样的,这两个都是表示空字符串,其中有一个重点是string str1= String.Empty和 string str2=null 的区别,这样定义后,str1是一个空字符串,空字符串是一个特殊的字符串,只不过这个字符串的值为空,在内存中是有准确的指向的,string str2=null,这样定义后,只是定义了一个string 类的引用,str2并没有指向任何地方,在使用前如果不实例化的话,都将报错。textBox1.Text的值为零长度字符串 ""。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|晨鸟科技 ( 沪ICP备09012675号 )

GMT+8, 2026-3-17 08:20 , Processed in 6.066639 second(s), 6 queries , Wincache On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表