在 MyBatis 中实现分页查询,通常有两种方法:物理分页和内存分页。这里我将分别介绍这两种方法。
物理分页是指通过数据库本身的分页功能来实现分页查询,这种方法性能较高,因为只需要查询当前页的数据,而不是查询所有数据。为了实现物理分页,你需要使用数据库的分页关键字(如 MySQL 的 LIMIT 和 OFFSET)来控制需要查询的数据范围。
首先,在你的 MyBatis 映射文件中编写分页查询的 SQL 语句,使用 LIMIT 和 OFFSET 关键字:
<select id="selectPage" parameterType="map" resultType="YourResultType">
SELECT * FROM your_table
LIMIT #{offset}, #{limit}
</select>
然后,在你的 Java 代码中,创建一个分页对象(如 PageInfo),并设置当前页码、每页显示的数据条数等信息:
public class PageInfo<T> {
private int pageNum; // 当前页码
private int pageSize; // 每页显示的数据条数
private int total; // 总数据条数
private List<T> list; // 当前页的数据列表
// 省略 getter 和 setter 方法
}
接下来,在你的业务逻辑中,调用 MyBatis 的分页查询方法,传入分页对象的相关参数:
public PageInfo<YourResultType> selectPage(int pageNum, int pageSize) {
PageInfo<YourResultType> pageInfo = new PageInfo<>();
pageInfo.setPageNum(pageNum);
pageInfo.setPageSize(pageSize);
Map<String, Object> params = new HashMap<>();
params.put("offset", (pageNum - 1) * pageSize);
params.put("limit", pageSize);
List<YourResultType> list = yourMapper.selectPage(params);
pageInfo.setList(list);
// 查询总数据条数
int total = yourMapper.countTotal();
pageInfo.setTotal(total);
return pageInfo;
}
内存分页是指先将所有数据查询出来,然后在内存中进行分页处理。这种方法性能较低,因为当数据量较大时,会消耗大量内存。内存分页主要用于数据量较小的情况。
首先,在你的 MyBatis 映射文件中编写查询所有数据的 SQL 语句:
<select id="selectAll" resultType="YourResultType">
SELECT * FROM your_table
</select>
然后,在你的 Java 代码中,创建一个分页对象(如 PageInfo),并设置当前页码、每页显示的数据条数等信息:
public class PageInfo<T> {
// 省略其他属性和 getter、setter 方法
}
接下来,在你的业务逻辑中,调用 MyBatis 的查询所有数据的方法,将查询结果存储在内存中进行分页处理:
public PageInfo<YourResultType> selectPage(int pageNum, int pageSize) {
PageInfo<YourResultType> pageInfo = new PageInfo<>();
pageInfo.setPageNum(pageNum);
pageInfo.setPageSize(pageSize);
List<YourResultType> allList = yourMapper.selectAll();
int total = allList.size();
pageInfo.setTotal(total);
int startIndex = (pageNum - 1) * pageSize;
int endIndex = Math.min(startIndex + pageSize, total);
pageInfo.setList(allList.subList(startIndex, endIndex));
return pageInfo;
}
这样,你就可以在 MyBatis 中实现分页查询了。根据你的实际需求,可以选择使用物理分页或内存分页。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。