晨鸟科技

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

解释SqlServer中null和''的区别

[复制链接]
跳转到指定楼层
楼主
发表于 2010-7-30 19:49:53 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
10金钱
本帖最后由 Star 于 2011-6-9 21:04 编辑 % [4 M% g$ a+ A6 ^6 Z" s, Y
7 ?3 {/ F& W, \  t' T% k
详细解释SqlServer中对于空字符的处理
! I! T& D% b- m6 ^一次存储过程中,以null作为if判断条件,存储过程执行的结果如:
5 ]: w+ Z4 X+ q% w1 ?3 x
7 \3 P+ n' r' |7 @而将所有的null替换成'',之后,执行结果如:
4 x$ ^! `+ t) A  X$ {/ j+ v& I. B+ V) T- A/ ^; a. W

) m6 U- j6 Y) q: K4 a请帮忙解释

附件: 您需要 登录 才可以下载或查看,没有帐号?注册
沙发
 楼主| 发表于 2010-7-30 20:02:54 | 只看该作者
【String.Empty,NULL和""的区别】
9 y0 x7 V6 I% ?8 E* {- U( \! b) m# y! m4 a6 z
string.Empty不分配存储空间
( [: J4 F: H6 Q' H! d# M      ""分配一个长度为空的存储空间   2 @; c* F" N9 B/ x8 z; z
      所以一般用string.Empty
* w) Y) K) ~% |- |) _+ F1 J0 f& h" m$ R
为了以后跨平台,还是用string.empty
( w, o6 c/ A( v, K
# J, _4 M( x% y4 [在 C# 中,大多数情况下 "" 和 string.Empty 可以互换使用。比如:
  W. v9 L: b& F6 `
/ ~, f! W. u6 ] string s = "";" `; ?" s4 x' C. R, l) L* B6 i
string s2 = string.Empty;' t) O6 U# s- V9 ~* Q
. W  _1 x$ n8 [6 R
if (s == string.Empty) {# h5 A* L( z' P& f1 v6 ^! Y
  // . k! ^0 y2 O1 x' I& [
}+ E: k  S+ \, z& j4 C" |
if语句成立
" J" E8 B) _' G. S  s* W
: U- o8 ~9 U7 \& E( c2 h1 g
  X3 |. l( N  E2 d# X, L判定为空字符串的几种写法,按照性能从高到低的顺序是:
! A( w3 ^6 b* _% U
" h4 w4 F4 W4 Qs.Length == 0      优于 s == string.Empty      优于 s == ""
" c$ m- s5 k/ t, u0 _8 `, U# r
' ?  {" a: l& i/ u
+ ]" ?$ g7 Q, q2 W3 c* h关于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 15:08 , Processed in 6.064686 second(s), 7 queries , Wincache On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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