时间:2021-05-19
最近用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 一对多分页查询问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
有时候我们在查询数据库时,需要以查询结果为查询条件进行关联查询。在mybatis中通过association标签(一对一查询,collection一对多查询)实
Mybatis中的一对多对象关联查询查询模拟情景,商品与商品详情:一件商品可以对应多个商品详情信息,即从商品➡商品详情方向看,属于一对多。在一对多
描述项目中用到boot整合mybatis-plus,个人在使用分页条件查询的时候一直查不出total,pages,终于找到原因了.环境2.1.5.RELEASE
项目中经常会使用到一对多的查询场景,但是PageHelper对这种嵌套查询的支持不够,如果是一对多的列表查询,返回的分页结果是不对的参考Github上的说明:h
mybatis-plus版本不兼容问题1,mybatis-plus版本中存在一个问题。2,mybatis-plus-extension版本为v3.2.1.1-S