晨鸟科技

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

解释SqlServer中null和''的区别

[复制链接]
跳转到指定楼层
楼主
发表于 2010-7-30 19:49:53 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
10金钱
本帖最后由 Star 于 2011-6-9 21:04 编辑 : o  l4 H+ i: s$ T$ T) s$ g
/ O) s3 T: v( u& [
详细解释SqlServer中对于空字符的处理
9 V! u4 X5 {) K9 q一次存储过程中,以null作为if判断条件,存储过程执行的结果如:
; m8 F, ?! M2 l* K
  Z5 E4 c5 o# ^6 x2 Q* n而将所有的null替换成'',之后,执行结果如:9 L# g2 k  Y- r$ [. ]
6 U) j9 O. L. }' }" O" p
5 g/ J" Q5 j" A; i% Z
请帮忙解释

附件: 您需要 登录 才可以下载或查看,没有帐号?注册
沙发
 楼主| 发表于 2010-7-30 20:02:54 | 只看该作者
【String.Empty,NULL和""的区别】' \. P# m, u6 W0 B% {" R! K$ e4 t' l
2 A& _; Q0 H3 L4 Y8 u' s
string.Empty不分配存储空间
6 ?; g7 Q; T  H/ D: B      ""分配一个长度为空的存储空间   . @9 T" r% B0 F6 ~2 ?
      所以一般用string.Empty: E# c5 F" ^, X+ G7 `
/ n& @; ^' ]6 I, q3 ]5 O
为了以后跨平台,还是用string.empty
3 j# l9 Z; H; q3 m9 W/ m4 p# w2 ]: ?" ^: a2 _  ^
在 C# 中,大多数情况下 "" 和 string.Empty 可以互换使用。比如:6 J5 i0 I2 z0 [4 F

4 J2 ~* E- U6 C string s = "";" j4 S/ @# g8 `0 l* Q. V
string s2 = string.Empty;
) [0 e# Y: l5 Q$ ]+ {/ J* E- [
' o; R: V7 ^$ K7 N! T* }if (s == string.Empty) {6 `1 K! k# z3 p
  //
1 g5 Q: E2 l9 t, B}
. g- E2 I# S; mif语句成立
/ j3 }) u: Z) {$ C% z+ q+ ~  c3 V$ y9 D' E) i% M/ G/ D6 A

/ T- n$ r3 [& g判定为空字符串的几种写法,按照性能从高到低的顺序是:; D1 m1 X7 o  F9 l
/ X- @+ P$ p( p: t8 D8 @
s.Length == 0      优于 s == string.Empty      优于 s == "" ' G  `- N3 P- }3 W. l% w; G7 U

  j: s) P/ K$ F! B) W3 V
. k8 k& V( V& `/ k关于String.Empty和Null的问题是这样的,这两个都是表示空字符串,其中有一个重点是string str1= String.Empty和 string str2=null 的区别,这样定义后,str1是一个空字符串,空字符串是一个特殊的字符串,只不过这个字符串的值为空,在内存中是有准确的指向的,string str2=null,这样定义后,只是定义了一个string 类的引用,str2并没有指向任何地方,在使用前如果不实例化的话,都将报错。textBox1.Text的值为零长度字符串 ""。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-16 11:29 , Processed in 6.065663 second(s), 7 queries , Wincache On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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