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",queryFields.getAreaId())
      .like("name",queryFields.getNameLike())
);
  • ExcludeEmptyQueryWrapper 代码如下:
/**
 * 继承QueryWrapper,重写其构造条件方法,使条件为null的查询条件,不再执行。
 * @since Mybatis+ version: 3.x.x
 * @author firewolf
 */
public class ExcludeEmptyQueryWrapper<T> extends QueryWrapper<T> {
    @Override
    public QueryWrapper<T> eq(boolean condition, String column, Object val) {
        condition = !Objects.isNull(val);
        return super.eq(condition, column, val);
    }

    @Override
    public QueryWrapper<T> ne(boolean condition, String column, Object val) {
        condition = !Objects.isNull(val);
        return super.ne(condition, column, val);
    }

    @Override
    public QueryWrapper<T> gt(boolean condition, String column, Object val) {
        condition = !Objects.isNull(val);
        return super.gt(condition, column, val);
    }

    @Override
    public QueryWrapper<T> ge(boolean condition, String column, Object val) {
        condition = !Objects.isNull(val);
        return super.ge(condition, column, val);
    }

    @Override
    public QueryWrapper<T> lt(boolean condition, String column, Object val) {
        condition = !Objects.isNull(val);
        return super.lt(condition, column, val);
    }

    @Override
    public QueryWrapper<T> le(boolean condition, String column, Object val) {
        condition = !Objects.isNull(val);
        return super.le(condition, column, val);
    }

    @Override
    public QueryWrapper<T> like(boolean condition, String column, Object val) {
        condition = !Objects.isNull(val);
        return super.like(condition, column, val);
    }

    @Override
    public QueryWrapper<T> notLike(boolean condition, String column, Object val) {
        condition = !Objects.isNull(val);
        return super.notLike(condition, column, val);
    }

    @Override
    public QueryWrapper<T> likeLeft(boolean condition, String column, Object val) {
        condition = !Objects.isNull(val);
        return super.likeLeft(condition, column, val);
    }

    @Override
    public QueryWrapper<T> likeRight(boolean condition, String column, Object val) {
        condition = !Objects.isNull(val);
        return super.likeRight(condition, column, val);
    }

    @Override
    public QueryWrapper<T> between(boolean condition, String column, Object val1, Object val2) {
        if(Objects.isNull(val1) && Objects.isNull(val2)){
            condition = false;
        }else if(Objects.isNull(val1)){
            return super.lt(true,column,val2);
        }else if(Objects.isNull(val2)){
            return super.ge(true,column,val1);
        }
        return super.between(condition, column, val1, val2);
    }

    @Override
    public QueryWrapper<T> notBetween(boolean condition, String column, Object val1, Object val2) {
        if(Objects.isNull(val1) && Objects.isNull(val2)){
            condition = false;
        }else if(Objects.isNull(val1)){
            return super.lt(true,column,val2);
        }else if(Objects.isNull(val2)){
            return super.ge(true,column,val1);
        }
        return super.notBetween(condition, column, val1, val2);
    }
}
Mybatis-plus分页查询无数据的问题可能有多种原因。首先,需要确保你的分页查询方法正确地配置了分页拦截器。在MybatisPlusConfig类中,你需要添加PaginationInnerInterceptor分页插件,并设置数据库类型为mysql。这样才能使分页查询功能生效。\[2\] 另外,你需要检查你的查询接口代码是否正确。在你的查询接口中,你需要传入正确的分页参数,并使用page方法进行分页查询。确保你的查询条件正确,并且与数据库中的数据匹配。\[3\] 如果你的分页查询仍然无数据,可能是因为数据库中没有符合查询条件的数据。你可以检查数据库中的数据是否正确,并且与你的查询条件匹配。如果数据库中确实没有符合条件的数据,那么分页查询将返回空结果。 总结起来,要解决mybatis-plus分页查询无数据的问题,你需要确保正确配置了分页拦截器,并且传入正确的分页参数和查询条件。同时,还需要检查数据库中是否有符合条件的数据。 #### 引用[.reference_title] - *1* *2* [mybatis-plus分页查询详解](https://blog.csdn.net/w1014074794/article/details/125787908)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [mybatis-plus 分页后没有数据问题(超过当前数据量的页)](https://blog.csdn.net/jj89929665/article/details/126590180)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值