SQL-三值逻辑和NULL
2022/2/15 2:11:40
本文主要是介绍SQL-三值逻辑和NULL,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
当表中存在NULL时,查询结果有时会与我们想的不一样
我们想查询z 是0 或者不是0的key(现实逻辑是,z是0或者不是0,二者必居其一)
SELECT `key` FROM table WHERE `z` = 0 OR `z` <> 0;
查询结果:
结果中并没有D!必须增加一个条件:
SELECT `key` FROM `greatests` WHERE `z` = 0 OR `z` <> 0 OR `z` IS NULL;
才能查询到正确结果:
以上证明关系模型并不是描述现实世界的模型,而是用于描述人类认知状态的核心(知识)的模型。
关于NULL,我们需要知道以下知识:
- NULL不是值
- NULL不是值,不能对其使用谓词(LIKE、CASE、ALL),使用的结果是UNKNOWN
- UNKNOWN参与到逻辑运算时,SQL的运行结果会和预想的不一样
- 在创建表时增加IS NOT NULL的限定并不能完全避免出现NULL的情况
UNKNOWN、FALSE、TRUE真值表
AND:
FALSE>UNKNOWN>TRUE
OR:
TRUE>UNKNOWN>FALSE
这篇关于SQL-三值逻辑和NULL的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-06-15matplotlib作图不显示3D图,怎么办?
- 2024-06-1503-Loki 日志监控
- 2024-06-1504-让LLM理解知识 -Prompt
- 2024-06-05做软件测试需要懂代码吗?
- 2024-06-0514-ShardingSphere的分布式主键实现
- 2024-06-03为什么以及如何要进行架构设计权衡?
- 2024-05-31全网首发第二弹!软考2024年5月《软件设计师》真题+解析+答案!(11-20题)
- 2024-05-31全网首发!软考2024年5月《软件设计师》真题+解析+答案!(21-30题)
- 2024-05-30【Java】百万数据excel导出功能如何实现
- 2024-05-30我们小公司,哪像华为一样,用得上IPD(集成产品开发)?