晨鸟科技

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

解释SqlServer中null和''的区别

[复制链接]
跳转到指定楼层
楼主
发表于 2010-7-30 19:49:53 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
10金钱
本帖最后由 Star 于 2011-6-9 21:04 编辑
) q0 |  [% \' L( @/ I
  |# A0 j: V3 [, V! H4 |详细解释SqlServer中对于空字符的处理
* @7 }8 u4 H9 f( x$ Y一次存储过程中,以null作为if判断条件,存储过程执行的结果如:
6 U/ ~5 F( N" ~! ~" i. x' p
2 T% [' H) a% S& s5 h" E而将所有的null替换成'',之后,执行结果如:
; s( p3 I  J& ]6 u, |( x
, Q1 H& R; u- g
# H" A9 M2 X* S请帮忙解释

附件: 您需要 登录 才可以下载或查看,没有帐号?注册
沙发
 楼主| 发表于 2010-7-30 20:02:54 | 只看该作者
【String.Empty,NULL和""的区别】* l3 X! W( j! M$ ]% S! A9 i

, o6 F9 p! m7 E3 [+ Mstring.Empty不分配存储空间
5 k7 v: U% \* t! d      ""分配一个长度为空的存储空间   7 p7 a  ~' b( Q" \% W2 D
      所以一般用string.Empty
" @  x: U% h  e2 W! I5 x, H, T! P) |# c- q. j1 y. R! o
为了以后跨平台,还是用string.empty
' T. T; n! T8 b4 Q0 x% g
: E3 p- Q: }; @. {在 C# 中,大多数情况下 "" 和 string.Empty 可以互换使用。比如:" L7 G$ E$ m  v0 Y5 m0 ~

# y9 z: @7 }* o5 a; z: n7 W; e string s = "";: ~( L( o7 ?& ~) m  `3 r& ?  K
string s2 = string.Empty;* W# }. U: h8 \( B9 H

7 S8 }# a! ~" |3 s% p2 pif (s == string.Empty) {
! w* Z# L+ e6 C# _& Q/ l$ e# v; E  // 6 F# B& m5 f, i2 Z; _$ @9 y$ k
}
2 t* b9 _5 h, h) }( [if语句成立
7 C/ o  X: Y5 \' Q2 m! ]
1 K) H, E( j% _5 u9 s) S* z
0 v/ e1 x. J$ L判定为空字符串的几种写法,按照性能从高到低的顺序是:
8 h) x: o& B1 ?; h+ E7 ^+ [0 j. g: D, C; d
s.Length == 0      优于 s == string.Empty      优于 s == "" 3 {& c# w/ M- M* O

% f. r  n8 K; x/ y- o$ y8 V
; Q+ p9 |( }: \3 D关于String.Empty和Null的问题是这样的,这两个都是表示空字符串,其中有一个重点是string str1= String.Empty和 string str2=null 的区别,这样定义后,str1是一个空字符串,空字符串是一个特殊的字符串,只不过这个字符串的值为空,在内存中是有准确的指向的,string str2=null,这样定义后,只是定义了一个string 类的引用,str2并没有指向任何地方,在使用前如果不实例化的话,都将报错。textBox1.Text的值为零长度字符串 ""。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-10-28 09:52 , Processed in 6.067615 second(s), 7 queries , Wincache On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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