Mysql系列 --- 关于null值注意事项

一、关于in、not in 中使用null

1. 使用in的时候,忽略为null的,不会查询出column为null的数据

SELECT * from poi_permission WHERE user_id IN (NULL,'12') 

    条件中只有null,返回0条数据

SELECT * from poi_permission WHERE user_id IN (NULL) 

2. 使用not in的时候,如果 not in后面的选项中没有null,只会查询column列不为null的数据,会过滤掉column为null的数据

SELECT * from poi_permission WHERE user_id NOT IN ('12','2') 

3.使用not in 的时候,如果not in后面的选项中有null,不会查询出来任何数据。sql语句本身直接返回false,所以使用not in的时候,要保证条件不会出现null的情况,否则可能会出现意想不到的情况。

SELECT * from poi_permission WHERE user_id NOT IN ('12','2',NULL) 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值