pagehelper 返回集合数据时,limit分页位置自定义

场景:
需要返回List<map>集合,且其中存在需要collection 进行部分集合数据进行汇总,因为pageHelper默认是在sql语句最后加入limit语句,就会导致最终的查询结果少于分页数量

解决:



第一步:重写helperDialect类继承MySqlDialect

import com.github.pagehelper.Page;
import com.github.pagehelper.dialect.helper.MySqlDialect;
import org.apache.ibatis.cache.CacheKey;

import java.util.regex.Pattern;

/**
 * @author LengChen
 * @version 1.0
 * @date 2022-03-29
 */
public class MySqlDialectCustom extends MySqlDialect {
    @Override
    public String getPageSql(String sql, Page page, CacheKey pageKey) {
        Pattern compileFixed = Pattern.compile("/\\*fixed\\*/");
        String compileLimit = "/\\*limit\\*/";
        if (compileFixed.matcher(sql).find()) {
            if (page.getStartRow() == 0) {
                sql = sql.replaceFirst(compileLimit, " LIMIT ? ");
            } else {
                sql = sql.replaceFirst(compileLimit, " LIMIT ?, ? ");
            }
            return sql;
        }
        return super.getPageSql(sql, page, pageKey);
    }
}

第二步:配置pagehelper.helperDialect

pagehelper: 
  helperDialect: com.ruoyi.framework.datasource.MySqlDialectCustom

第三步:sql编写

/*fixed*/为标记此sql需要自定义limit
/*limit*/为真正需要填写limit语句的位置


<select id="selectRecruitRangeListMap" resultMap="rangeListMap">
/*fixed*/
        SELECT
            r.range_id,r.range_name,r.range_num,r.batch_num,r.setting_id,d1.dept_id,d1.dept_name
        FROM
            (
                SELECT
                    dept_id,
                    dept_name
                FROM
                    sys_dept d
                WHERE
                    FIND_IN_SET(
                        d.dept_id,
                        '100,200,201,202,203'
                    )
                    /*limit*/
            ) d1
        LEFT JOIN recruit_range r ON d1.dept_id = r.dept_id AND r.setting_id = '2022' AND r.del_flag = '0'
    </select>

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PageHelper是一个用于分页查询的Java工具,它可以帮助我们方便地进行分页操作。在PageHelper中,我们可以通过设置`pageSize`和`pageNum`来指定每页显示的记录数和当前页数。如果我们想要自定义每页显示的记录数,可以使用`PageHelper.startPage(pageNum, pageSize)`方法来设置。 下面是一个示例代码,演示了如何使用PageHelper自定义每页显示的记录数: ```java import com.github.pagehelper.PageHelper; import com.github.pagehelper.PageInfo; public class Example { public static void main(String[] args) { // 设置每页显示的记录数为10 int pageSize = 10; // 设置当前页数为1 int pageNum = 1; // 使用PageHelper.startPage方法设置分页参数 PageHelper.startPage(pageNum, pageSize); // 执行查询操作,获取查询结果列表 List<User> userList = userDao.selectUserList(); // 使用PageInfo对查询结果进行包装 PageInfo<User> pageInfo = new PageInfo<>(userList); // 获取分页信息 int total = pageInfo.getTotal(); // 总记录数 int pages = pageInfo.getPages(); // 总页数 List<User> result = pageInfo.getList(); // 当前页的记录列表 // 输出分页信息和查询结果 System.out.println("总记录数:" + total); System.out.println("总页数:" + pages); System.out.println("当前页的记录列表:" + result); } } ``` 在上面的示例中,我们通过`PageHelper.startPage(pageNum, pageSize)`方法设置了每页显示的记录数为10。然后执行查询操作,获取查询结果列表。最后使用`PageInfo`对查询结果进行包装,可以获取到分页信息和当前页的记录列表。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值