admin 管理员组文章数量: 1086019
2024年1月14日发(作者:手机怎么保存网页视频)
SQL的null值
SQL中的NULL值,表示不知道(UNKNOWN)的数据,用作不知道数据的具体值,或者不知道数据是否存在,或者数据不存在等情况。因为引入了NULL值,故此SQL的逻辑系统是三值逻辑系统——FALSE、TRUE、NULL三种值构成的逻辑系统。 1、OR、AND、NOT真值表 A
FALSE
FALSE
FALSE
TRUE
TRUE
TRUE
NULL
NULL
NULL
B
FALSE
TRUE
NULL
FALSE
TRUE
NULL
FALSE
TRUE
NULL
A OR B
FALSE
TRUE
NULL
TRUE
TRUE
TRUE
NULL
TRUE
NULL
A AND B
FALSE
FALSE
FALSE
FALSE
TRUE
NULL
FALSE
NULL
NULL
NOT A
TRUE
‐
‐
FALSE
‐
‐
NULL
‐
‐
因为NULL当UNKNOWN来理解,因此,当值为NULL时,它既有可能是FALSE也有可能是TRUE。如果计算结果只有一种可能,则取该种可能;如果计算结果既有可能是FALSE,也有可能是TRUE,那么结果便为NULL。例如,NOT NULL,其结果也有两种可能,因此NOT NULL的结果是NULL。再例如,NULL AND TRUE,则其结果也有两种可能,因此NULL AND TRUE的结果是NULL。但是,NULL OR TRUE,或是NULL AND FALSE,前者结果为TRUE,单是一个TRUE出现,便足以知道结果为TRUE;后者结果为FALSE,单是一个FALSE出现,便足以知道结果为FALSE。这是OR和AND的特性决定的。 2、比较运算符及算术运算符中的NULL 比较运算符及算术运算符中的NULL,会导致运算结果也为NULL。如3+NULL的结果为NULL,NULL>=5的结果为NULL,等等。 3、BETWEEN AND、IN中的NULL A BETWEEN B AND C意为A>=B AND A<=C,因此其产生NULL值的情况,可以参照后者判断。A NOT BETWEEN B AND C相应等价于NOT(A>=B AND A<=C)。 A IN(B,C,D)意为A=B OR A=C OR A=D,因此其产生NULL值的情况,可以参照后者判断。A NOT IN(B,C,D)相应等价于NOT(A=B OR A=C OR A=D)。当集合为空时,IN的结果为FALSE,NOT IN的结果则为TRUE。 4、EXISTS、IS NULL
EXISTS(以及NOT EXISTS)、IS NULL(以及IS NOT NULL),均只产生FALSE或TRUE,而不产生NULL。 5、ANY、ALL 在一个值与一个集合(一组值)比较时,比较运算符可以加上ANY(或SOME,作用相同)或ALL。 A>ANY(B,C,D)意为A>B OR A>C OR A>D,因此其产生NULL值的情况,可以参照后者判断。当集合为空时,ANY的结果为FALSE。 A>ALL(B,C,D)意为A>B AND A>C AND A>D,因此其产生NULL值的情况,可以参照后者判断。当集合为空时,ALL的结果为TRUE。 6、WHERE、HAVING、ON条件筛选,与完整性约束检查 在WHERE、HAVING、ON条件筛选中,只保留结果为TRUE的,而不处理FALSE及NULL的。但在完整性约束检查中,只有结果为FALSE的,才违反约束检查,NULL并不违反。
版权声明:本文标题:数据库 SQL的null值 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://roclinux.cn/b/1705219727a477380.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论