解决mybatis plus 一对多分页查询问题

 更新时间:2020年11月30日 10:09:03   作者:shrek11  
这篇文章主要介绍了解决mybatis plus 一对多分页查询问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

最近用mybatis plus做项目,单表的增删改查都正常,做到

1对多表的分页时,用resultMap返回的时候发现返回的记录和总数对不上

返回的记录是 一 表的,二返回的总数是 多 表

查了一下,这个或者是PLUS的bug

大概的解决办法如下图:用collection,传参用column,我这里用了一个小技巧,

把外面传入的参数,作为主表的column传入到从表。

这里没找到其他方法,有其他方法可以评论告诉我

补充知识:解决Mybatis-plus利用collection查询一对多分页数据的Bug

今天开发一个分页功能的时候,前端找我说数据不对。自己测试了一下,果然有问题。

请求参数如下:

相应结果如下(字段太多,删除了一些非关键字段):

total是总记录数的意思,有4条,但是结果只有3条。

网上搜索一番,定位到问题所在,这个是mybatis-plus关于分页的一个bug,我这里的collection写法如下(其中collection还有javaType属性,这里回退代码没有回退到底):

需要改一下collection的写法,分成两次查就可以了:

说明:

column是关联的id,意思就是根据哪个字段来查询关联表的字段;另外需要删除原来写法下一个select语句中collection下的字段(因为现在转移到了第二个select中)。

这种写法存在一个问题就是:dao中的参数传递不到collection对应的select语句中,collection对应的select语句的条件参数只能来自外层column属性。

通过修改为上面写法后,按照网上的说法就没问题了,但是我这里报了序列化的错误(因为postman测试工具中内容太长,就粘贴到了文本编辑器中):

网上搜索了一下,是需要相关实体类实现序列化接口并且在类上添加注解@JsonIgnoreProperties(value = {“handler”}),作用是json序列化时忽略bean中的一些属性序列化和反序列化时抛出的异常:

然后在请求测试就可以了,结果就不贴出来了。

写在最后:collection对应的从表和主表关联条件必须在collection层级存在,不然在resultMap中会映射不到。

以上这篇解决mybatis plus 一对多分页查询问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Java8使用LocalDate计算日期实例代码解析

    Java8使用LocalDate计算日期实例代码解析

    这篇文章主要介绍了Java8使用LocalDate计算实例代码解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-04-04
  • Java-Io-RandomAccessFile任意位置读写数据的操作小结

    Java-Io-RandomAccessFile任意位置读写数据的操作小结

    RandomAccessFile类支持随机访问方式,可以跳转到文件的任意位置读写数据,这个类在文件随机读取时有很大的优势,可利用多线程完成对一个大文件的读写,本文给大家介绍Java-Io-RandomAccessFile(任意位置读写数据)的相关知识,需要的朋友可以参考下
    2022-05-05
  • 详解Flutter TabLayout 布局用法

    详解Flutter TabLayout 布局用法

    Flutter是谷歌的移动UI框架,可以快速在iOS和Android上构建高质量的原生用户界面。这篇文章主要介绍了Flutter TabLayout 布局用法,需要的朋友可以参考下
    2019-07-07
  • SpringBoot项目通过Feign调用三方接口的详细教程

    SpringBoot项目通过Feign调用三方接口的详细教程

    本文主要介绍了Spring Boot中使用Feign调用第三方接口的步骤,包括环境搭建、接口定义、DTO映射、配置请求头与超时、日志及错误处理,感兴趣的可以了解一下
    2025-08-08
  • 使用controller传boolean形式值

    使用controller传boolean形式值

    这篇文章主要介绍了使用controller传boolean形式值,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • Java并发编程之对象的组合

    Java并发编程之对象的组合

    这篇文章主要介绍了Java并发编程之对象的组合,文章基于Java的相关资料展开主题内容,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-04-04
  • 快速排序算法在Java中的实现

    快速排序算法在Java中的实现

    这篇文章主要介绍了快速排序算法在Java中的实现,简单介绍了快速排序的实现原理,分享了两种实现代码,具有一定参考价值,需要的朋友可以了解下。
    2017-11-11
  • 升级IDEA后Lombok不能使用的解决方法

    升级IDEA后Lombok不能使用的解决方法

    最近看到提示IDEA提示升级,寻思已经有好久没有升过级了。升级完毕重启之后,突然发现好多错误,本文就来介绍一下如何解决,感兴趣的可以了解一下
    2021-07-07
  • Java 输入输出 IO NIO AIO三兄弟对比分析对比分析

    Java 输入输出 IO NIO AIO三兄弟对比分析对比分析

    这篇文章主要为大家介绍了Java 输入输出 IO NIO AIO三兄弟对比分析对比分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • 如何使用IDEA开发Spark SQL程序(一文搞懂)

    如何使用IDEA开发Spark SQL程序(一文搞懂)

    Spark SQL 是一个用来处理结构化数据的spark组件。它提供了一个叫做DataFrames的可编程抽象数据模型,并且可被视为一个分布式的SQL查询引擎。这篇文章主要介绍了如何使用IDEA开发Spark SQL程序(一文搞懂),需要的朋友可以参考下
    2021-08-08

最新评论