"=NULL"和"Is NULL"

        今天在MSN Blog中,偶然看到同事抱怨用OLEDB连接数据库执行SQL,用"=NULL"不能返回想要的结果集,但用"Is NULL"却可以。因此,他认为这是数据库的一个Bug。

       其实,在数据库中,NULL值表示Unknow。所以,SQL92标准规定NULL不能用=、>、<比较,而需要用IS (NOT) NULL。
       某些数据库允许不按照SQL92标准进行NULL比较,但此时返回的值是不确定的。如果你事先给字段赋了NULL值,则“=NULL”可以返回TRUE;反之,数据库通常会对这种比较进行忽略。
       为了保证结果的唯一性,推荐所有地方都使用IS (NOT) NULL。

       可以参见MSDN的相关文章。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值