博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
你真的会玩SQL吗?让人晕头转向的三值逻辑
阅读量:6071 次
发布时间:2019-06-20

本文共 962 字,大约阅读时间需要 3 分钟。

先来看一个问题:a not in (b,c,null),返回什么?

是不是有时辛辛苦苦写了个查询,但显示的不是想要的答案?让我们来看看其中的一个陷阱。

我们筛选为某列值为NULL的行,一般会采用如下的方式:select * from tb where col=null

但这无法得到我们想要的结果的,正确的方式是col is null 为什么呢?这就涉及到三值逻辑。

三值逻辑

在SQL中逻辑表达式的可能值包括TRUE、FALSE和UNKNOWN。它们被称之为三值逻辑。

三值逻辑是SQL所特有的。大多数编程语言的逻辑表达式只有TRUE或FALSE两种值。

SQL中的UNKNOWN逻辑值通常出现在包含NULL值的逻辑表达式中,例如,下面这三个表达式值都是UNKNOWN: 

NULL<42;NULL=NULL;X+NULL>Y;

UNKNOWN值也是确定的,只是不同情况下有时为true有时为false,一个总原则是:UNKNOWN值非真即假,非假即真,UNKNOWN只能取true和false中的一个,但UNKNOWN的相反还是UNKNOWN

在on\where和having中做过滤条件时,UNKNOWN看作false,在check中被看作true,在条件中两个null比较结果是UNKNOWN。(建设表中包含一个CHECK约束,要求salary列的值必须大于0,向该表插入salary为NULL时可以被接受,因为(NULL>0)等于UNKNOWN,在check约束中被视为和TRUE一样)

在筛选器中比较两个NULL值将得到UNKNOWN,它会被当作false处理,就好像其中一个NULL不等于另一个NULL。

而UNIQUE约束。排序操作和分组操作认为两个NULL值是相等的。

如果表中有一列定义了UNIQUE约束,将无法向表中插入该列值为NULL的两行。

GROUP BY 子句把所有NULL值分到一组。

ORDER BY 子句把所有NULL值排列在一起。

 

知道了为什么在查询中筛选null的时候需要使用 is null 或者is not null ,常规条件表达式却无法筛选出?

练习

以下对就返回哪三值?

答案

 

转载于:https://www.cnblogs.com/8080zl/p/8603098.html

你可能感兴趣的文章
我的友情链接
查看>>
获取颜色值转换为十六进制
查看>>
IP相关知识复习
查看>>
行业大佬集体唱衰教育O2O,强管控的B2C模式将是唯一出路
查看>>
Ubuntu的JSP服务器安装
查看>>
Centos 6.4 下设置静态IP,指定NAMESERVER(DNS),修改网卡MAC地址
查看>>
阿里工程师开发了一款免费工具,提升Kubernetes应用开发效率
查看>>
cisco防火墙ASA5505配置
查看>>
MySQL 表栏位类型选择
查看>>
官网下载Google Chrome离线安装包
查看>>
Linux 系统常用的性能监测命令工具
查看>>
lvresize 指令
查看>>
Xamarin如何生成Android项目的APK
查看>>
Fabric实战
查看>>
PAT 1003. Emergency
查看>>
三星i9300 unroot || root恢复
查看>>
jsp基础知识
查看>>
离线安装db2的python模块ibm_db
查看>>
环境变量
查看>>
Swift 项目中可能用到的第三方框架
查看>>