晨鸟科技

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

解释SqlServer中null和''的区别

[复制链接]
跳转到指定楼层
楼主
发表于 2010-7-30 19:49:53 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
10金钱
本帖最后由 Star 于 2011-6-9 21:04 编辑 - s5 N" A" {. ]9 j7 t, h
* f5 J- p5 [" S5 M8 ^2 [& d. A
详细解释SqlServer中对于空字符的处理& b" a4 E% [0 b' ]* L
一次存储过程中,以null作为if判断条件,存储过程执行的结果如:: j* ~$ {$ d4 U0 V5 e
( z7 i: o/ ~( \% W" {& ]" u& `
而将所有的null替换成'',之后,执行结果如:
. j2 |4 o5 b: l& g% @; M4 J( X$ q
; ]* G' B3 U  p/ t/ i7 Z* w: o' P: g8 @
请帮忙解释

附件: 您需要 登录 才可以下载或查看,没有帐号?注册
沙发
 楼主| 发表于 2010-7-30 20:02:54 | 只看该作者
【String.Empty,NULL和""的区别】
1 h' H' j; [$ M/ t* I8 J; k! v- C/ O4 y/ h- U' ~
string.Empty不分配存储空间
" Y* a3 k1 s' a: c" N0 f9 K0 H      ""分配一个长度为空的存储空间   
, q9 X4 D9 L7 ?      所以一般用string.Empty- d9 g8 K( r3 ^! {3 m
4 }5 N+ Q" w, X, r6 s- B
为了以后跨平台,还是用string.empty2 t# i/ B8 b2 ]

2 K' ^/ B* [# a5 w在 C# 中,大多数情况下 "" 和 string.Empty 可以互换使用。比如:
8 M1 I" H' R) `
/ c' M# S6 L9 j string s = "";
: z2 a" s9 z' U  ^, o' Astring s2 = string.Empty;
9 S. V, L! Q/ Q+ C- L' G+ G  V; L& u/ X* o) k/ v& }9 T5 Y' a' s
if (s == string.Empty) {' p; X, ~' ?8 ]5 l
  //
& [, G4 |/ U+ X0 S2 d( D  U}; z( `' u0 x# [1 A+ v
if语句成立 - x. h  q$ c" z

( @& z$ V6 m5 j$ r- e6 }. o$ @  G- ?& H% ?  C
判定为空字符串的几种写法,按照性能从高到低的顺序是:4 J, F  N! v  i' G3 E! x

# s6 z0 h% ~; Y1 zs.Length == 0      优于 s == string.Empty      优于 s == ""
7 f+ N0 r4 V" [1 X) F% U4 [; G$ Q9 M$ R9 b: x% \, x# H' B
9 W/ M- U. i, K6 ~7 F
关于String.Empty和Null的问题是这样的,这两个都是表示空字符串,其中有一个重点是string str1= String.Empty和 string str2=null 的区别,这样定义后,str1是一个空字符串,空字符串是一个特殊的字符串,只不过这个字符串的值为空,在内存中是有准确的指向的,string str2=null,这样定义后,只是定义了一个string 类的引用,str2并没有指向任何地方,在使用前如果不实例化的话,都将报错。textBox1.Text的值为零长度字符串 ""。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-10-29 03:53 , Processed in 6.085194 second(s), 6 queries , Wincache On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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