多表查询的分页处理

单表分页

直接调MP的Page方法就行了

多表查询分页

以前我是这样写的
手动分页。
在这里插入图片描述
实际上有更加简单的写法

 IPage<ReadingRecordVo> getAppCurrentReadingMeterList(Page<Object> page,@Param("accountId") Long accountId);

调用的时候,传一个Page对象。这样就没必要手动分页了。

pagehelper是一个开源的Java分页插件,可以方便地实现多表查询分页功能。使用pagehelper进行多表查询分页,需要进行以下几个步骤: 1. 首先,在你的项目中引入pagehelper的依赖。可以在pom.xml文件中添加以下代码: ```xml <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper</artifactId> <version>最新版本号</version> </dependency> ``` 2. 在需要进行多表查询分页的Mapper接口的方法上,使用@Select注解定义查询语句。查询语句可以包含多个表的关联查询,并通过使用PageHelper.startPage方法设置分页参数。例如: ```java @Select("SELECT a.id, a.name, b.age FROM table_a a LEFT JOIN table_b b ON a.id = b.a_id") List<YourResultType> selectMultiTableData(); ``` 3. 在Service层或者Controller层调用Mapper接口的相应方法,获取查询结果。例如: ```java PageHelper.startPage(pageNum, pageSize); // 设置分页参数 List<YourResultType> resultList = yourMapper.selectMultiTableData(); ``` 4. 处理分页结果。可以通过将查询结果封装到PageInfo对象中,获取分页相关信息。例如: ```java PageInfo<YourResultType> pageInfo = new PageInfo<>(resultList); long total = pageInfo.getTotal(); // 获取总记录数 List<YourResultType> data = pageInfo.getList(); // 获取当前页数据列表 ``` 这样就实现了多表查询分页的功能。可以根据具体的业务需求,调整查询语句和分页参数的设置。注意,PageHelper.startPage方法需要在实际查询之前调用,以便正确地进行分页
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值