晨鸟科技

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

解释SqlServer中null和''的区别

[复制链接]
跳转到指定楼层
楼主
发表于 2010-7-30 19:49:53 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
10金钱
本帖最后由 Star 于 2011-6-9 21:04 编辑
  D' j( B* A9 Y' }& }) Y' W9 f* G, l3 `3 ], W: ~
详细解释SqlServer中对于空字符的处理
, a/ q% I' g5 N) c0 Q& {; [! F一次存储过程中,以null作为if判断条件,存储过程执行的结果如:
, d2 n. \, P" a% x9 n  L: @5 f: o  J& E- D# [
而将所有的null替换成'',之后,执行结果如:/ M  d: ^5 A. q+ T; R. o, E
8 @1 y2 a6 F% n  v& a! C& S2 Q
2 h, D6 h. r. ^1 }
请帮忙解释

附件: 您需要 登录 才可以下载或查看,没有帐号?注册
沙发
 楼主| 发表于 2010-7-30 20:02:54 | 只看该作者
【String.Empty,NULL和""的区别】
2 H8 T; L9 ~' R3 i. _2 B
$ g9 K& H+ j4 F& i) J2 ystring.Empty不分配存储空间) o8 ?% A( M8 P0 U1 M4 u: t
      ""分配一个长度为空的存储空间   $ H; [# ~- u( H: B; W8 z
      所以一般用string.Empty* O; \' T( P3 w) T- G# }1 k
; \' o  z/ L- [% D; |
为了以后跨平台,还是用string.empty8 r" d  p# q' N5 w6 u" a. j& {' G

+ P; b) {$ j; b$ }& s. w在 C# 中,大多数情况下 "" 和 string.Empty 可以互换使用。比如:
$ n: ?7 f+ |" v% {+ Y; h* C6 N5 a8 U* s0 y' V& ^: I; K5 i5 q
string s = "";
- y: }+ t; r' j8 z" K8 B4 H7 S5 Vstring s2 = string.Empty;/ Z$ y# B7 E4 V; w6 _6 ~6 Q
( Q7 L8 e  v! G
if (s == string.Empty) {
& |8 [: b" V% z: A! F  //
% W2 I3 R+ M& G2 ]}
- M, v+ V5 l4 ~. {  v+ s0 |  O/ ]8 nif语句成立 # ]% {- H2 C+ J* p) b3 f; I
" b4 }9 h0 u. }+ P& z
' _# N5 t! w) d! @: y
判定为空字符串的几种写法,按照性能从高到低的顺序是:
1 u5 b( p( U9 O* [
( f- P- M1 ~4 b/ S7 Qs.Length == 0      优于 s == string.Empty      优于 s == "" / W9 k6 a, m- V
* x  _" N7 o" }1 m& D5 z

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

本版积分规则

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

GMT+8, 2025-6-21 11:18 , Processed in 6.065662 second(s), 7 queries , Wincache On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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