晨鸟科技

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

解释SqlServer中null和''的区别

[复制链接]
跳转到指定楼层
楼主
发表于 2010-7-30 19:49:53 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
10金钱
本帖最后由 Star 于 2011-6-9 21:04 编辑
9 }1 A2 C3 ^. p$ k5 j/ Y
# A- B* m; E5 y3 n0 _9 ?详细解释SqlServer中对于空字符的处理& Z) S0 r# v6 C& g! }# _3 Q+ h. S
一次存储过程中,以null作为if判断条件,存储过程执行的结果如:( V2 W1 {" ?: l5 z* _# J

. W+ @1 o1 j% y2 I) U% M! C# c1 [- ]+ t而将所有的null替换成'',之后,执行结果如:9 n0 n$ S7 J! H; F! o) B

* o. R. X% U( f: ~2 z$ ~: S! u9 s$ l) l: Z- _, C( Z8 c. k2 B
请帮忙解释

附件: 您需要 登录 才可以下载或查看,没有帐号?注册
沙发
 楼主| 发表于 2010-7-30 20:02:54 | 只看该作者
【String.Empty,NULL和""的区别】
8 c/ ]7 G- g  ~8 o  x2 D0 _! c0 v! i& G$ |3 L% z
string.Empty不分配存储空间
3 a- i+ l/ C; D      ""分配一个长度为空的存储空间   
( L& c3 j; C9 z. u* Y      所以一般用string.Empty
$ k* u7 l7 I/ P( K  H; J5 }( D+ q5 l/ c8 t
为了以后跨平台,还是用string.empty
/ |" M3 r* u3 m. M
) b: K) |# n  I3 V+ z- G在 C# 中,大多数情况下 "" 和 string.Empty 可以互换使用。比如:
' I6 D5 a: a! O
( p+ H& y6 A  {5 o) ~' B4 ` string s = "";
8 D; h  X3 \# A: O! `5 wstring s2 = string.Empty;
, }& |- ]6 m, b3 w
. u8 o3 o  Z0 J+ X* J6 T) ]) U4 Jif (s == string.Empty) {
; c5 G1 |# }* K1 ^9 ^' Q; p  // 4 V8 y  K6 t. I  D
}
3 Z( C* {4 Q" m9 k2 l% Hif语句成立
( P9 |' E7 T0 u+ r3 L% h2 ^! \. _" @5 Z2 z, [5 q: A/ Y6 m0 S
  ^# s4 y) I" f# [6 `" e7 y
判定为空字符串的几种写法,按照性能从高到低的顺序是:
) l4 Q; y, d+ O) e. U  i$ g6 ]& }' H8 b6 L3 u" ^3 O# e; w- R* t9 U6 _
s.Length == 0      优于 s == string.Empty      优于 s == "" 4 Y+ U, x; B- q) y" C
) }8 u# X. V3 {% g& i8 w" i' b0 X2 ]9 S( y

' Y5 U# e1 \3 \5 y' ]% c5 D关于String.Empty和Null的问题是这样的,这两个都是表示空字符串,其中有一个重点是string str1= String.Empty和 string str2=null 的区别,这样定义后,str1是一个空字符串,空字符串是一个特殊的字符串,只不过这个字符串的值为空,在内存中是有准确的指向的,string str2=null,这样定义后,只是定义了一个string 类的引用,str2并没有指向任何地方,在使用前如果不实例化的话,都将报错。textBox1.Text的值为零长度字符串 ""。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-8-13 14:06 , Processed in 6.061136 second(s), 6 queries , Wincache On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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