解决Mybatis-plus利用collection查询一对多分页数据的Bug

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

请求参数如下:
解决Mybatis-plus利用collection查询一对多分页数据的Bug
相应结果如下(字段太多,删除了一些非关键字段):
解决Mybatis-plus利用collection查询一对多分页数据的Bug
total是总记录数的意思,有4条,但是结果只有3条。

网上搜索一番,定位到问题所在,这个是mybatis-plus关于分页的一个bug,我这里的collection写法如下:
解决Mybatis-plus利用collection查询一对多分页数据的Bug
需要改一下collection的写法,分成两次查就可以了:
解决Mybatis-plus利用collection查询一对多分页数据的Bug
说明:column是关联的id,意思就是根据哪个字段来查询关联表的字段;另外需要删除原来写法下一个select语句中collection下的字段(因为现在转移到了第二个select中)。

通过修改为上面写法后,按照网上的说法就没问题了,但是我这里报了序列化的错误(因为postman测试工具中内容太长,就粘贴到了文本编辑器中):
解决Mybatis-plus利用collection查询一对多分页数据的Bug
网上搜索了一下,是需要相关实体类实现序列化接口并且在类上添加注解@JsonIgnoreProperties(value = {“handler”}),作用是json序列化时忽略bean中的一些属性序列化和反序列化时抛出的异常:
解决Mybatis-plus利用collection查询一对多分页数据的Bug
然后在请求测试就可以了,结果就不贴出来了。