一、关于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)