晨鸟科技

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

解释SqlServer中null和''的区别

[复制链接]
跳转到指定楼层
楼主
发表于 2010-7-30 19:49:53 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
10金钱
本帖最后由 Star 于 2011-6-9 21:04 编辑
, x1 m9 F! y  @" _* J  A/ M5 h$ r) `- f
详细解释SqlServer中对于空字符的处理
3 p2 u# ~. x; m/ R6 D' X/ Q; e/ M3 e一次存储过程中,以null作为if判断条件,存储过程执行的结果如:: D, J  w4 j5 s7 U: Y( t7 a
6 B+ W$ ], E; K+ t: K
而将所有的null替换成'',之后,执行结果如:$ f8 S+ [/ A3 i, f- ?) f* v0 R; \

4 J1 y6 s  W8 V: w) d3 H# P9 L- S3 F' J% H1 Z. V  i# |
请帮忙解释

附件: 您需要 登录 才可以下载或查看,没有帐号?注册
沙发
 楼主| 发表于 2010-7-30 20:02:54 | 只看该作者
【String.Empty,NULL和""的区别】
' W! C; t1 T* q- i5 ^8 V
: P- Y4 G! ]' q" \string.Empty不分配存储空间0 G* @1 G0 A! `' f
      ""分配一个长度为空的存储空间   * S6 C" Q$ s) H- f( I% C
      所以一般用string.Empty& i( B, z1 f6 g. S; x
* _1 T+ N) ?% c5 ?- P
为了以后跨平台,还是用string.empty
/ g4 D1 {2 |8 s1 g) W
) y* ^1 Q% J( X  o' i在 C# 中,大多数情况下 "" 和 string.Empty 可以互换使用。比如:
+ \9 ~/ `* l( ]
* \# }" A3 Q1 X' A string s = "";
' x" k; l" `/ O/ p" W  Fstring s2 = string.Empty;
/ X# i  e$ h! y" L( r* t2 V/ f0 c  v
if (s == string.Empty) {
1 m. m& e2 O6 O2 m  //
. |$ O  ~5 q3 ~  M8 U}
5 n- e$ E3 Y1 f& H: _if语句成立 9 _6 `  G( F. Z

/ W+ K2 L# L! q' [6 e
9 O0 o- S/ q8 m  d8 f" h判定为空字符串的几种写法,按照性能从高到低的顺序是:3 J" }' {) e4 i* R, ~. E
" n$ C3 S8 C! Q- `! U/ |
s.Length == 0      优于 s == string.Empty      优于 s == "" - B; d/ I5 ]4 q& y8 M* b  D

- G' v8 g8 [9 c2 @# j0 p* x8 J+ I7 b
) g1 S1 V2 f$ t$ {  X, M; z* F8 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-15 05:14 , Processed in 6.063089 second(s), 7 queries , Wincache On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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