在构造条件生成器的时候,如果对字段a想做查询所有a字段不为空的查询,首先要实例一个条件构造器,如下:
LambdaQueryWrapper<T> lambdaQueryWrapper = new LambdaQueryWrapper<>()
然后我第一次编写代码的时候,使用了如下方式
lambdaQuertWrapper.ne(T::getA, null);
但是查到的结果为[ ],正常如果顺利的话,应该查到满足条件的一个List<T>。
于是我在重新尝试使用NotNULL来进行筛选,如下:
lambdaQuertWrapper.isNotNull(T::getA);
修改之后,能够正确查询出筛选之后的数据。
【总结】
'ne'(not equal)此方法进行比较时,会自动生成一个 ' != ' 的SQL条件,而这个sql条件对检查字段不等于某个字段值是有效的,但是在某些数据库中,' != null ' 这样的条件不会返回任何结果,因为sql标准,任何值与 ' null ' 的比较结果都为NULL,所以才会出现上述查不到数据的情况。
并且isNotNull时专门用于检查字段是否不为Null的条件,在所有数据库中都是一致的,所以这个方法可以正常查询到我们所构造的条件器的所查询的正确数据。