对于单表查询是没有问题的。而需要多表关联查询(自写sql)时,就会查询调用Mybatis-Plus的
.page(E page, Wrapper queryWrapper);
方法是就就会出现查询总数不对问题。
我这边业务比较复杂,是做项目的时候发现的问题,(本人比较懒)没有重新写demo。所以就不要太关注业务逻辑。只要知道符合条件的数据是69条。
正常使用分页查询时的代码
运行的查询sql后台日志打印情况
可以看到Mybatis-Plus框架分页查询时,使用了两次查询,先查询总条数,再查询数据。而做了优化就是给第一个查询进行了优化(只查主表符合查询条件的总条数),这就导致两条查询sql的表数量不一致,从而导致查询总条数不一致的情况。搞清楚了原因,那就好解决了。
代码调整(关闭分页查询优化)
Page<Object> toPage = (Page<Object>) pageQuery.toPage();
toPage.setOptimizeCountSql(false);
运行的查询sql后台日志打印情况
可以看到两次查询sql是一致的。解决问题。拜了个拜