PageHelper 分页排序使用记录

PageHelper  分页使用

PageHelper.startPage(pageNum, pageSize, orderBy);

其中最后一个参数是数据库字段名称,按传入的字段进行排序

场景:如果有接口参数中有排序字段,则按参数中的排序字段来排序,如果没有按sql中的order by 来排序。

接口参数如下

接口如下:

    /**
     * 排序列
     */
    public static final String ORDER_BY_COLUMN = "orderByColumn";

    /**
     * 排序的方向 "desc" 或者 "asc".
     */
    public static final String IS_ASC = "isAsc";

    /**
     * 封装分页对象
     */
    public static PageDomain getPageDomain(Integer pageNum, Integer pageSize) {
        PageDomain pageDomain = new PageDomain();
        pageDomain.setPageNum(pageNum);
        pageDomain.setPageSize(pageSize);
        pageDomain.setOrderByColumn(ServletUtils.getParameter(ORDER_BY_COLUMN));
        pageDomain.setIsAsc(ServletUtils.getParameter(IS_ASC));
        return pageDomain;
    }    

    /**
   * 设置请求分页数据
     */    

protected void startPage() {
        PageDomain pageDomain = TableSupport.buildPageRequest();
        Integer pageNum = pageDomain.getPageNum();
        Integer pageSize = pageDomain.getPageSize();
        if (StringUtils.isNotNull(pageNum) && StringUtils.isNotNull(pageSize)) {
            String orderBy = SqlUtil.escapeOrderBySql(pageDomain.getOrderBy());
            PageHelper.startPage(pageNum, pageSize, orderBy);
        }
    }


/**
* 接口调用
*/

    @PostMapping("/list")
    public TableDataInfo list(@RequestBody SysSubplatTaskComm sysSubplatTaskComm)
    {
        startPage();
        List<SysSubplatTaskComm> list = sysSubplatTaskCommService.selectSysSubplatTaskCommList(sysSubplatTaskComm);
        return getDataTable(list);
    }



sql如下:

 

 

PageHelper源码中替换了原sql中的order by time,使用参数中create_time的排序字段拼接

原sql

 去除原sql中排序

 

 执行结果如下:

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PageHelper 是一个用于 MyBatis 的分页插件,可以方便地实现数据库查询结果的分页功能。下面是使用 PageHelper 的步骤: 1. 在 Maven 或 Gradle 项目的 `pom.xml`(或 `build.gradle`)文件中添加 PageHelper 依赖: ```xml <!-- Maven --> <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper</artifactId> <version>latest-version</version> </dependency> ``` ```groovy // Gradle implementation 'com.github.pagehelper:pagehelper:latest-version' ``` 请确保将 `latest-version` 替换为最新版本号。 2. 修改 MyBatis 配置文件(通常是 `mybatis-config.xml`),在 `<configuration>` 标签下添加 PageHelper 的插件配置: ```xml <plugins> <plugin interceptor="com.github.pagehelper.PageInterceptor"> <property name="dialect" value="your-database-dialect"/> <!-- 其他配置属性 --> </plugin> </plugins> ``` 这里的 `your-database-dialect` 需要根据你使用的数据库类型来设置,例如对于 MySQL 可以设置为 `mysql`。 3. 在需要分页查询的方法中加入分页参数,并调用 PageHelper 的静态方法 `startPage` 来开启分页功能。 ```java import com.github.pagehelper.PageHelper; public List<User> getUsers(int pageNum, int pageSize) { // 开始分页pageNum 表示当前页码,pageSize 表示每页显示的记录PageHelper.startPage(pageNum, pageSize); // 查询数据库,获取结果列表 List<User> users = userDao.getUsers(); return users; } ``` 这样,PageHelper 就会自动在查询语句中添加分页的 SQL 语句,完成分页查询的功能。 请注意,PageHelper 还提供了很多其他的配置和使用方式,例如设置排序,自定义分页参数等,你可以根据具体需求参考官方文档进行配置和使用

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值