加入收藏 | 设为首页 | 会员中心 | 我要投稿 莱芜站长网 (https://www.0634zz.com/)- 云连接、建站、智能边缘云、设备管理、大数据!
当前位置: 首页 > 数据库 > MsSql > 正文

SQL 复合查询条件(AND,OR,NOT)对NULL值的处理方法

发布时间:2020-10-19 11:52:15 所属栏目:MsSql 来源:互联网
导读:在SQL的3值逻辑下,一个查询条件可以产生以下三种情况:TRUE,FALSE,NULL。只有那些满足WHERE子句的值是TRUE的记录才出现在结果表中。

NULL值影响查询条件的结果,并且结果很微妙。

以下是SQL中AND,OR,NOT的真值表。

表1 AND的真值表

表2 OR的真值表 表3 NOT的真值表

当两个以上的查询条件与AND、OR、NOT组合时,NOT的优先级最高,其次是AND,最后是OR。为了避免歧义和确保可移植性最好使用括号。

A

BETWEEN

B

AND

C 等价于 (A>=B)

AND

(A<=C),因此根据真值表可以得出BETWEEN 子句中处理NULL值的规则。

同样,A

IN

(B,C,D) 等价于 (A=B)

OR

(A=C)

OR

(A=D),根据真值表,只要这三个表达式中有一个为NULL,结果返回肯定是NULL。

因此,

BETWEEN子句和

IN子句

并不增加SQL语句的表达能力。

SQL 中有

NULL

值测试,即:

字段

IS (

NOT

) NULL,但它的返回结果只有两种情况:TRUE或者FALSE。

(编辑:莱芜站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读