Spring分页的几种方法

一、mysql前端请求参数包括page_num和page_size, 首先对这两个参数进行合法性判断,然后重新计算下page_num,让当前page_num对应的就是你要定位到的第n条数据,比如现在要查看第6页数据,且page_size=7,那也就是要获取到第37行-43行数据。复习下mysql中limit的使用:LIMIT 子句可以被用于强制 SELECT 语句返回指定的记录数。LIMIT 接受一个或两个数字参数。参数必须是一个整数常量。如果给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二
摘要由CSDN通过智能技术生成

一、mysql

前端请求参数包括page_num和page_size, 首先对这两个参数进行合法性判断,然后重新计算下page_num,让当前page_num对应的就是你要定位到的第n条数据,比如现在要查看第6页数据,且page_size=7,那也就是要获取到第37行-43行数据。
复习下mysql中limit的使用:
LIMIT 子句可以被用于强制 SELECT 语句返回指定的记录数。LIMIT 接受一个或两个数字参数。参数必须是一个整数常量。如果给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二个参数指定返回记录行的最大数目。初始记录行的偏移量是 0(而不是 1)。
所以,对于上述情况,对应的偏移量=(7-1)*6=36。

if (page_num != null && page_size != null) {
   
    page_num = (page_num - 1) * page_size;
}
List<Example> data = exampleMapper.getExample(page_num, page_size);

.xml中sql语句示例:

<select id="getExampleByPage" resultMap="AllExampleInfo">
		select * 
		from Example
		limit #{page},#{size}
</select>

二、拦截器:

源码在这:https://github.com/pagehelper/Mybatis-PageHelper 实际上就是省了我们去重复写相同逻辑的代码,而且分页返回结果中有很多详细参数。

  1. 添加maven依赖:
<dependency>
    <groupId>com.</
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 1. 使用 `java.sql.Statement` 类的 `setMaxRows` 和 `setFetchSize` 方法来设置每页的记录数,然后使用 `java.sql.ResultSet` 类的 `absolute` 方法来跳转到指定页。 2. 使用 `java.sql.PreparedStatement` 类的 `setMaxRows` 和 `setFetchSize` 方法来设置每页的记录数,然后使用 `java.sql.ResultSet` 类的 `absolute` 方法来跳转到指定页。 3. 使用 `SELECT` 语句的 `LIMIT` 和 `OFFSET` 子句来限制查询返回的行数。 4. 使用 `java.sql.Statement` 或 `java.sql.PreparedStatement` 对象的 `executeQuery` 方法执行带有 `LIMIT` 和 `OFFSET` 子句的 `SELECT` 语句,然后使用 `java.sql.ResultSet` 类的 `next` 方法来遍历查询结果。 5. 使用数据库的特定功能(如 MySQL 的 `LIMIT` 子句)来实现分页。这种方法的实现方式取决于数据库的类型。 ### 回答2: Java实现分页查询的几种常用方法有: 1.使用SQL语句的LIMIT关键字:在查询数据库时,可以使用LIMIT关键字来指定查询结果的起始位置和数量。通过计算页号PageNum和每页数量PageSize,可以得到SQL语句中的LIMIT子句,从而实现分页查询。 2.使用MyBatis的分页插件:MyBatis是一种优秀的持久化框架,在其配置文件中可以配置分页插件,并使用插件提供的分页功能完成分页查询。通过在Mapper接口中定义查询方法,并在配置文件中配置插件,可以方便地实现分页逻辑。 3.使用Spring Data JPA的分页查询:Spring Data JPA是一种简化数据库操作的框架,可以通过定义Repository接口来实现数据的增删改查操作。在查询方法中,可以使用Pageable参数来指定查询结果的起始位置和数量,从而实现分页查询。 4.使用PageHelper插件:PageHelper是一种基于MyBatis的分页插件,提供了丰富的分页查询功能。在查询方法中,可以通过调用PageHelper.startPage方法来指定页号和每页数量,PageHelper会自动在SQL语句中添加LIMIT子句,从而实现分页查询。 5.使用自定义工具类:可以自定义一个工具类来实现分页查询逻辑。通过传入查询结果集合、页号和每页数量,可以在工具类中进行计算,得到分页查询的结果集合。 以上是Java实现分页查询的几种常用方法,根据项目的需求和使用的框架,可以选择适合的方法来实现分页功能。 ### 回答3: Java实现分页查询有多种方法,以下是几种常见的实现方式: 1. 使用数据库的分页查询:在SQL语句中使用LIMIT关键字,通过设置偏移量和每页显示的数据条数,实现分页效果。例如,使用MySQL数据库时,可以通过"SELECT * FROM table_name LIMIT offset, limit"语句来实现分页查询。 2. 使用集合分页:将查询结果全部加载到内存中的集合中,然后通过对集合进行切片操作,截取指定页的数据,实现分页效果。常见的集合类如List、ArrayList等都提供了subList方法,可以方便地实现分页。 3. 使用ORM框架:ORM(Object-Relational Mapping)框架如Hibernate、MyBatis等,提供了丰富的分页查询功能。通常只需在查询方法中传入页码和每页显示的数据数量,框架会自动生成对应的分页查询SQL语句,并返回分页查询结果。 4. 使用第三方库:有一些开源的分页查询库可以直接使用,如PageHelper、Spring Data JPA等。这些库提供了简单易用的API,可以快速实现分页查询功能。 需要注意的是,无论使用哪种方法实现分页查询,都要考虑性能和数据量。当处理大数据量时,应尽量减少数据库查询次数,避免一次性加载全部数据;同时,合理使用缓存、索引等技术,提高查询效率。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值