关于sql中子查询not in 后面不能为null的理解

平时在sql查询中都要注意not in后面的条件中不能有null,如果有null就没有返回结果了,而in后面有null依然可以有返回结果。
说下我的理解:
in后面的子句可以理解为or拼接
比如

select * from t_student where height in(175, 177, null)

后面的height in (175, 177, null)可以理解为height =175 or height =177 or height =null只要满足一项判断,整条判断就算true,于是这条记录就会被放到结果集里面

而not in 后面的子句可以理解为and 拼接
height not in (175, 177, null) 可以理解为 height != 175 and != 177 and != null
在数据库中任何有null参与的比较运算都会被算做false,所以一项判断为false,整条判断就算false,于是记录就不会被放到结果集里面。

再放上几个关于null的“坑”

  • 如果null参与算术运算,则该算术表达式的值为null。(例如:+,-,*,/ 加减乘除)
  • 如果null参与比较运算,则结果可视为false。(例如:>=,<=,<> 大于,小于,不等于)
  • 如果null参与聚集运算,则聚集函数都置为null(使用isnull(字段,0)等方式可以避免这种情况)。除count(*), count(1), count(0)等之外(count(字段) 字段为null的行不参与计数)。
  • 如果在not in子查询中有null值的时候,则不会返回数据。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值