温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

利用mybatis plus怎么实现一个一对多分页查询功能

发布时间:2020-12-01 16:11:56 来源:亿速云 阅读:4222 作者:Leah 栏目:开发技术

这篇文章将为大家详细讲解有关利用mybatis plus怎么实现一个一对多分页查询功能,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

最近用mybatis plus做项目,单表的增删改查都正常,做到1对多表的分页时,用resultMap返回的时候发现返回的记录和总数对不上返回的记录是 一  表的,二返回的总数是多 表查了一下,这个或者是PLUS的bug大概的解决办法如下图:用collection,传参用column,我这里用了一个小技巧,把外面传入的参数,作为主表的column传入到从表。

利用mybatis plus怎么实现一个一对多分页查询功能

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

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

请求参数如下:

利用mybatis plus怎么实现一个一对多分页查询功能

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

利用mybatis plus怎么实现一个一对多分页查询功能

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

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

利用mybatis plus怎么实现一个一对多分页查询功能

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

利用mybatis plus怎么实现一个一对多分页查询功能

说明:

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

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

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

利用mybatis plus怎么实现一个一对多分页查询功能

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

利用mybatis plus怎么实现一个一对多分页查询功能

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

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

关于利用mybatis plus怎么实现一个一对多分页查询功能就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI