平时在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值的时候,则不会返回数据。