这篇写的是postgres,但是实际上我简单试了对于mysql也是适用的.
先简单介绍下背景,这是前几天线上的一个真实bug. 很久之前产品经理要求某个列表页排除某些类型,开发一气呵成写完上线,非常完美,突然前几天产品说现在不需要排除这几个类别了,就把要排除的配置项给清空了,结果发现列表页也空了,造成大事故啊。
我检查发现问题代码大致如下
const products = models.Product.findAll({ productType: { $notIn: excludedTypeIds },})
看着毫无bug是不是?ORM最终出来的的sql大致是
select * from product where product_type NOT IN (1,2,3,4)
但是考虑下excludedTypeIds是空数组的情况,SQL会变成
select * from product where product_type NOT IN (NULL)
看着似乎也没问题,这个sql的结果应该是所有product的列表吧?
实际上不是的,这个查询的结果为空。问题就出在NULL上.
在postgresql里,