Mybatis第七讲 原始分页实现 PageHelper的分页

分页插件-PageHelper

原始分页实现
显示所有的页码数

​ 1、总的数据条数 total

​ 2、每页要显示的数据数量是多少 count

​ 3、总页码数 total%count==0?total/count:(total/count+1)

每页要显示的数据来源

​ 1、起始位置

​ 2、固定的排序方式(查询的条件一致)

起始下标和页码数之间的关系
在这里插入图片描述

public class PageInfo {

	/**
	 * 总数据条数
	 */
	private int totals;
	
	/**
	 * 每页要显示的数据条数
	 */
	private int pageCount;
	
	/**
	 * 总页数
	 */
	private int pageTotals;
	
	/**
	 * 起始下标
	 */
	private int startIndex;
	
	/**
	 * 当前的页码数
	 */
	private int pageIndex;

	public int getTotals() {
		return totals;
	}

	public void setTotals(int totals) {
		this.totals = totals;
		if(totals%pageCount==0) {
			setPageTotals(totals/pageCount);
		}else {
			setPageTotals(totals/pageCount+1);
		}
	}

	public int getPageCount() {
		return pageCount;
	}

	public void setPageCount(int pageCount) {
		this.pageCount = pageCount;
	}

	public int getPageTotals() {
		return pageTotals;
	}

	public void setPageTotals(int pageTotals) {
		this.pageTotals = pageTotals;
	}

	public int getStartIndex() {
		return startIndex;
	}

	public void setStartIndex(int startIndex) {
		this.startIndex = startIndex;
	}

	public int getPageIndex() {
		return pageIndex;
	}
	//通过前台传递过来的页码数设置对应的起始下标
	public void setPageIndex(int pageIndex) {
		this.pageIndex = pageIndex;
		setStartIndex((pageIndex-1)*pageCount);
	}

	@Override
	public String toString() {
		return "PageInfo [totals=" + totals + ", pageCount=" + pageCount + ", pageTotals=" + pageTotals
				+ ", startIndex=" + startIndex + ", pageIndex=" + pageIndex + "]";
	}
	
}
<!-- 分页查询 -->
<select id="queryUsersLimit" parameterType="pageInfo" resultType="user">
    select <include refid="baseUser"/> from t_user users
    limit #{startIndex},#{pageCount}
</select>
@Test
public void testQueryUsersLimit() {
    IUserDao userDao = sqlSession.getMapper(IUserDao.class);
    //当前页的页码数
    int pageIndex = 3;
    //每页要显示的条数
    int pageCount = 5;
    PageInfo info = new PageInfo();
    info.setPageCount(pageCount);
    info.setStartIndex((pageIndex-1)*pageCount);
    List<User> userList = userDao.queryUsersLimit(info);
    System.out.println(userList);
}
/**
	 * 分页查询
	 * @param req
	 * @param userDao
	 * @param out
	 */
public void queryUsersLimit(HttpServletRequest req,IUserDao userDao,PrintWriter out) {
    String infoJson = req.getParameter("info");
    PageInfo info = JSON.parseObject(infoJson, PageInfo.class);
    List<User> userList = userDao.queryUsersLimit(info);
    String jsonData = JSON.toJSONString(userList);
    out.write(jsonData);
}

在这里插入图片描述

PageHelper的分页

导入相关的jar

​ pageHelper.jar jsqlparser.jar

配置拦截器(拦截通过Mybatis发送的请求)

<plugins>
 <!-- com.github.pagehelper为PageHelper类所在包名 -->
 <plugin interceptor="com.github.pagehelper.PageInterceptor"></plugin>
</plugins>

代码中的使用

@Test
public void testQueryUsers() {
 IUserDao userDao = sqlSession.getMapper(IUserDao.class);
 PageHelper.startPage(1, 5);
 List<User> userList = userDao.queryUsers();
 System.out.println(userList);
}

注意:分页插件只能对紧邻的第一个查询语句生效
使用postman测试
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,这里给您提供一个MyBatis框架中的分页插件PageHelper的具体使用案例。 1.引入依赖 在Maven中引入PageHelper的依赖: ```xml <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper</artifactId> <version>5.2.0</version> </dependency> ``` 2.配置插件 在MyBatis的配置文件中配置PageHelper插件: ```xml <plugins> <plugin interceptor="com.github.pagehelper.PageInterceptor"> <property name="dialect" value="mysql"/> </plugin> </plugins> ``` 这里使用的是MySQL数据库,如果是其他数据库,可以将dialect属性值设置为相应的数据库类型。 3.使用插件 在需要进行分页查询的方法中,设置分页参数: ```java public List<User> getUsers(int pageNum, int pageSize) { //设置分页参数 PageHelper.startPage(pageNum, pageSize); //执行查询 List<User> userList = userMapper.selectUsers(); //返回查询结果 return userList; } ``` 这里的参数pageNum表示当前页码,pageSize表示每页显示的记录数。 4.获取分页信息 在查询结果中,可以通过PageInfo对象获取分页信息: ```java public PageInfo<User> getUsers(int pageNum, int pageSize) { //设置分页参数 PageHelper.startPage(pageNum, pageSize); //执行查询 List<User> userList = userMapper.selectUsers(); //获取分页信息 PageInfo<User> pageInfo = new PageInfo<>(userList); //返回分页信息 return pageInfo; } ``` 通过PageInfo对象,可以获取总记录数、总页数、当前页码等分页信息。 以上就是MyBatis框架中的分页插件PageHelper的具体使用案例,希望能对您有所帮助。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值