0


MybatisPlus使用Left Join...on...一对多多表联查和Ipage分页返回数据问题

问题:

一对多关系表使用MybatisPlus的Ipage进行分页查询,会先执行联表查询sql语句,然后进行分页。

像图中联表查询一对多关系,会有多条重复数据,使用Ipage分页会将这10条数据返回到xml中resultMap绑定的type。造成一页展示的数据少于10条。

针对这种我们采用子查询的方式解决:

一对多关系,

property:主表中关联表的属性名,

column: 主表传递给子查询的字段

select:子查询的方法

javaType:返回的类型

mapper接口

// 分页主表查询
IPage<List<UsedCar>> queryUsedCarSearchListCopy(@Param("page") IPage<UsedCar> pageUtil,@Param("params") Map<String, Object> params);

// 子查询方法名
List<UsedCarImage> queryImageList(@Param("carId") Long carId);
    // service层
    @Override
    public PageUtils queryPage(Map<String, Object> params) {
        QueryWrapper<UsedCar> queryWrapper = new QueryWrapper<>();
// Ipage分页,
        IPage<UsedCar> pageUtil = new Page<UsedCar>(Long.parseLong((String) params.get("page")),Long.parseLong((String) params.get("limit")));
// Ipage作为参数传递
        IPage<List<UsedCar>> page =usedCarMapper.queryUsedCarSearchListCopy(pageUtil,params);
        PageUtils pageUtils = new PageUtils(page);
        return pageUtils;
    }

主表查询:

子查询sql,通过select进行了绑定

#{carId}是主查询传递过来的字段

,mybatisPlus分页一对多关联表查询,可以正常显示了

标签: sql 数据库 mysql

本文转载自: https://blog.csdn.net/xiaomingboke/article/details/129956762
版权归原作者 你开心是我想要的 所有, 如有侵权,请联系我们删除。

“MybatisPlus使用Left Join...on...一对多多表联查和Ipage分页返回数据问题”的评论:

还没有评论