MybatisPlus使用Left Join...on...一对多多表联查和Ipage分页返回数据问题
短信预约 -IT技能 免费直播动态提醒
问题:
一对多关系表使用MybatisPlus的Ipage进行分页查询,会先执行联表查询sql语句,然后进行分页。
像图中联表查询一对多关系,会有多条重复数据,使用Ipage分页会将这10条数据返回到xml中resultMap绑定的type。造成一页展示的数据少于10条。
针对这种我们采用子查询的方式解决:
一对多关系,
property:主表中关联表的属性名,
column: 主表传递给子查询的字段
select:子查询的方法
javaType:返回的类型
mapper接口
// 分页主表查询IPage> queryUsedCarSearchListCopy(@Param("page") IPage pageUtil,@Param("params") Map params);// 子查询方法名List queryImageList(@Param("carId") Long carId);
// service层 @Override public PageUtils queryPage(Map params) { QueryWrapper queryWrapper = new QueryWrapper<>();// Ipage分页, IPage pageUtil = new Page(Long.parseLong((String) params.get("page")),Long.parseLong((String) params.get("limit")));// Ipage作为参数传递 IPage> page =usedCarMapper.queryUsedCarSearchListCopy(pageUtil,params); PageUtils pageUtils = new PageUtils(page); return pageUtils; }
主表查询:
子查询sql,通过select进行了绑定
#{carId}是主查询传递过来的字段
,mybatisPlus分页一对多关联表查询,可以正常显示了
来源地址:https://blog.csdn.net/xiaomingboke/article/details/129956762
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341