晨鸟科技

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

解释SqlServer中null和''的区别

[复制链接]
跳转到指定楼层
楼主
发表于 2010-7-30 19:49:53 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
10金钱
本帖最后由 Star 于 2011-6-9 21:04 编辑
7 N, b( T, l8 `* ^( {
# H. D* l! ?& c1 W8 S详细解释SqlServer中对于空字符的处理3 |" Q7 m: C% s5 o! g- _
一次存储过程中,以null作为if判断条件,存储过程执行的结果如:8 q" j! D, |4 a. }* |

% `, P* M( y( O8 k5 n, b, A; n而将所有的null替换成'',之后,执行结果如:  B. j# @+ F/ k8 U1 e
2 o$ g! e' U' I  X

/ ^/ w$ Q; x2 H- v% ^5 Q+ H1 ^/ D请帮忙解释

附件: 您需要 登录 才可以下载或查看,没有帐号?注册
沙发
 楼主| 发表于 2010-7-30 20:02:54 | 只看该作者
【String.Empty,NULL和""的区别】8 ~- U( F& N) y: e

: c8 r! n7 G( F, i0 s. T5 N( ^0 F# pstring.Empty不分配存储空间2 S3 Z; S: \$ L- `2 R8 ]$ j
      ""分配一个长度为空的存储空间   
5 u( }* S) w( h9 J# ^7 ]0 w      所以一般用string.Empty
! r8 C5 D2 h4 b, a3 X1 \! s" |( W3 ^! H
为了以后跨平台,还是用string.empty
. [5 u- D8 Z; B+ A& E5 _. C1 I' {. N" V! X  D
在 C# 中,大多数情况下 "" 和 string.Empty 可以互换使用。比如:7 ]' s7 H1 v# a# s4 b
+ v1 n7 z8 a9 _  ~
string s = "";  z: P' v: D2 }* V0 x
string s2 = string.Empty;6 h0 C5 Q5 P' t  e

7 S4 L+ y! }* c* T' t+ R. Fif (s == string.Empty) {
% s' d7 a7 g6 i  i" D+ x6 l  //   |' _, K* f" n. _( K- v& v
}7 l0 q& F3 I( N# e/ Q
if语句成立 ' ~% @- n' ?/ s8 @1 ^( n  e0 w
8 m( B1 v$ Z0 y
0 @: {# L; }  P2 E" L* @/ |
判定为空字符串的几种写法,按照性能从高到低的顺序是:
" a3 q7 ?! I( Q/ x: m' h$ k( y5 x7 X$ \/ y9 l
s.Length == 0      优于 s == string.Empty      优于 s == ""
5 A9 ]: l2 T9 O
5 j$ H/ J( y% s2 @, J! P0 V& L" I/ u/ U& ?' c% {0 m( `
关于String.Empty和Null的问题是这样的,这两个都是表示空字符串,其中有一个重点是string str1= String.Empty和 string str2=null 的区别,这样定义后,str1是一个空字符串,空字符串是一个特殊的字符串,只不过这个字符串的值为空,在内存中是有准确的指向的,string str2=null,这样定义后,只是定义了一个string 类的引用,str2并没有指向任何地方,在使用前如果不实例化的话,都将报错。textBox1.Text的值为零长度字符串 ""。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-12-12 20:36 , Processed in 6.065663 second(s), 7 queries , Wincache On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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