一
先在pom.xml中进行导包操作。
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>5.1.2</version>
</dependency>
二
在 ApplicationContext.xml中,
sqlSessionFactory 下配置分页配置。
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 注入数据库连接池 -->
<property name="dataSource" ref="dataSource"/>
<!-- 扫描bean,使用别名 -->
<property name="typeAliasesPackage" value="com.zrgj.bean"></property>
<!-- 配置加载映射文件 -->
<property name="mapperLocations" value="classpath:mapper/*.xml"/>
<!-- 分页配置 -->
<property name="plugins">
<array>
<bean class="com.github.pagehelper.PageInterceptor">
<property name="properties">
<props>
<prop key="helperDialect">mysql</prop>
<prop key="reasonable">true</prop>
</props>
</property>
</bean>
</array>
</property>
</bean>
三
Service中,给到具体的分页页码page,每页条数size,同时开启分页。
public interface IUserInfoService {
List<UserInfo> findAll(Integer page, Integer size);
}
四
Controller中把得到的数据保存到PageInfo。
这里设置一页里面设置五条数据。
public ModelAndView findAll(@RequestParam(defaultValue = "1") Integer page, @RequestParam(defaultValue = "5") Integer size){
List<UserInfo> userInfoList = userInfoService.findAll(page,size);
PageInfo pi = new PageInfo(userInfoList);
ModelAndView mv = new ModelAndView();
mv.addObject("pi",pi);
mv.setViewName("user-list");
return mv;
}
五
页面取值 – PageInfo.list
<div class="box-tools pull-right">
<ul class="pagination">
<li><a href="${pageContext.request.contextPath}/userInfoController/findAll.do?page=1&size=5" aria-label="Previous">首页</a></li>
<li><a href="${pageContext.request.contextPath}/userInfoController/findAll.do?page=${pi.pageNum-1}&size=5">上一页</a></li>
<c:forEach begin="1" end="${pi.pages}" var="pageNums">
<li><a href="${pageContext.request.contextPath}/userInfoController/findAll.do?page=${pageNums}&size=5">${pageNums}</a></li>
</c:forEach>
<li><a href="${pageContext.request.contextPath}/userInfoController/findAll.do?page=${pi.pageNum+1}&size=5">下一页</a></li>
<li><a href="${pageContext.request.contextPath}/userInfoController/findAll.do?page=${pi.pages}&size=5" aria-label="Next">尾页</a></li>
</ul>
</div>