mybatis-plus条件生成器对null的筛选

        在构造条件生成器的时候,如果对字段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的条件,在所有数据库中都是一致的,所以这个方法可以正常查询到我们所构造的条件器的所查询的正确数据。

        

     

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值