MybatisPlus自定义SQL多表条件查询,找不到列,count会报错问题

4 篇文章 1 订阅
3 篇文章 0 订阅

如何使用MybatisPlus自定义SQL多表条件查询请看Mybatis-Plus多表分页加条件自定义sql查询(三表查询)

在使用MybatisPlus自定义SQL进行多表条件查询时会报错,报错信息如下
IPage封装条件查询后,使用IService的page查询后,他会封装各种信息进IPage,封装IPage.total时,会再次进行一次COUNT(*)查询,但是此时查询条件其他表的字段,会报没有找到字段,SQL语句异常
在这里插入图片描述
先来查看官方文档描述
官方文档

解决方法:

  1. page.setOptimizeCountSql(false);
    这个方法比较简单,是对查询结果封装进行优化,代码如下
    // 分页查询数据
    Page<LendList> page = new Page<>(pageNo, pageSize);
    // 对多表查询后的结果进行count(*)
    page.setOptimizeCountSql(false);
    IPage<LendList> lendListIPage = lendRecordMapper.getLendList(page, wrapper);
    
    可以看到这次查询时,它是对条件查询分页后的数据进行COUNT(*)计数
    查询COUNT(*)
  2. Page<VO> page = new Page<>(pageNo, pageSize, false);
    注意第三个参数为false,这是不查询count,需要自己对count进行查询封装
    在这里插入图片描述

个人推荐使用第一种方法

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值