Mybatis-Plus 实现查询条件为空时不生效

当我们查询条件中的值不确定是否有空值时,我们期待查询时,Mybatis+能自动帮我们判空。

比如这样:

this.page(
      new Query<OperatorsEntity>().getPage(queryFields),
      new QueryWrapper<OperatorsEntity>()
      .eq("province_id",queryFields.getProvinceId())
      .eq("city_id",queryFields.getCityId())
      .eq("area_id",queryFields.getAreaId())
      .like("name",queryFields.getNameLike())
);

我们期待的结果是:“province_id”、“city_id”、“area_id”、"name"等几个字段中,如果有空的(比如查询表单中没有填这个查询条件),就不查询。
然而事实上,如果这样去写,结果会是:Mybatis+把所有条件都构造出来,为空的就按null查询,like则是查询: %null%

解决方案:

  • 提供一个有条件排空功能的ExcludeEmptyQueryWrapper(后附代码),有类似需求的用该queryWrapper来构建条件,一劳永逸解决问题,使用:
this.page(
      new Query<OperatorsEntity>().getPage(queryFields),
      new ExcludeEmptyQueryWrapper<OperatorsEntity>()
      .eq("province_id",queryFields.getProvinceId())
      .eq("city_id",queryFields.getCityId())
      .eq("area_id"
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值