PageHelper插件实现服务器端分页功能

 更新时间:2019年07月27日 18:45:45   作者:Miss_min  
这篇文章主要为大家详细介绍了PageHelper插件实现服务器端分页功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了PageHelper插件实现服务器端分页功能,供大家参考,具体内容如下

一、添加依赖

在.pom文件中添加

<dependency>
 <groupId>com.github.pagehelper</groupId>
 <artifactId>pagehelper</artifactId>
 <version>3.5.1</version>
</dependency>

二、添加配置/strong>

在spring-mybaits.xml文件中添加插件

<!-- mybatis和spring完美整合,不需要mybatis的配置映射文件 -->
 <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
  <property name="dataSource" ref="dataSource"/>
  <!-- 自动扫描mapping.xml文件 -->
  <property name="mapperLocations" value="classpath:mapping/*.xml"></property>
  <!--分页插件-->
  <property name="plugins">
   <array>
    <bean class="com.github.pagehelper.PageHelper">
     <property name="properties">
      <value>
       dialect=mysql
       reasonable=true
      </value>
     </property>
    </bean>
   </array>
  </property>
  <!--分页-->
</bean>

三、controller代码

//分页展示用户
 @RequestMapping(value = "/user.do")
 public ModelAndView test1(HttpServletRequest request, HttpServletResponse response, ModelMap mode) throws Exception {

  ModelAndView modelAndView = new ModelAndView();
  int pageNumber = 1;
  try{
   if(request.getParameter("pageNow").equals(null)){
    System.out.println("参数空");
   }else {
    pageNumber = Integer.parseInt(request.getParameter("pageNow"));
   }
  }catch (Exception e){
   //处理空针错误
  }

  System.out.println("请求参数"+request.getParameter("pageNow"));
  PageInfo<user> pageInfo = userService.selectUserByPage(pageNumber,5);

//  Map<String, Object> map = new HashMap<String, Object>();
//  List<Object> data = new ArrayList<Object>();
//  for(user admin : pageInfo.getList()){
//   Map<String, Object> obj = new HashMap<String, Object>();
//   obj.put("id", admin.getId());
//   obj.put("username", admin.getUsername());
//   obj.put("password", admin.getPassword());
//   obj.put("enable", admin.getEnable());
//   obj.put("id_card", admin.getIdCard());
//   obj.put("phone", admin.getPhone());
//   obj.put("address", admin.getAddress());
//   obj.put("nick_name", admin.getAddress());
//   data.add(obj);
//  }
  modelAndView.addObject("pageInfo",pageInfo); //jsp 根据users来传递信息
  System.out.println("成功啦");
  modelAndView.setViewName("/test/user");
  return modelAndView;
 }

四、Service方法

//分页获取用户信息
public PageInfo<User> selectUserByPage(Integer pageNum, Integer pageSize) {

 PageHelper.startPage(pageNum, pageSize);
 // 所有用户信息
 List<User> authAdmins = userMapper.selectUsers();
 if(authAdmins == null){
  return null;
 }
 PageInfo<User> pageInfo = new PageInfo<User>(authAdmins);
 return pageInfo;
}

五、jsp显示

<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%--
 Created by IntelliJ IDEA.
 User: Administrator
 Date: 2017/12/2 0002
 Time: 11:10
 To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
 <title>user</title>
</head>
<body>
<h1>User</h1>
<table>
 <c:forEach items="${pageInfo.list}" var="u">
  <%--属性值映射mapper 中的property--%>
  <tr>
   <td>${u.id}</td>
   <td>${u.username}</td>
   <td>${u.password}</td>
   <td>${u.enable}</td>
   <td>${u.idCard}</td>
   <td>${u.phone}</td>
   <td>${u.address}</td>
   <td>${u.nickName}</td>
  </tr>
 </c:forEach>

 <tr>
  <td colspan="6">
   <!-- 分页功能 start -->
   <div align="center">
    <font size="2">共 ${pageInfo.pageSize} 页</font> <font size="2">第
    ${pageInfo.pageNum} 页</font> <a href="${pageContext.request.contextPath}/user.do?pageNow=1" rel="external nofollow" rel="external nofollow" >首页</a>
    <c:choose>
     <c:when test="${pageInfo.pageNum - 1 > 0}">
      <a href="${pageContext.request.contextPath}/user.do?pageNow=${pageInfo.pageNum - 1}" rel="external nofollow" >上一页</a>
     </c:when>
     <c:when test="${pageInfo.pageNum - 1 <= 0}">
      <a href="${pageContext.request.contextPath}/user.do?pageNow=1" rel="external nofollow" rel="external nofollow" >上一页</a>
     </c:when>
    </c:choose>
    <%--pageSize共 页--%>
    <%--pageNum 第 页--%>
    <%--pagetotal 共 条--%>
    <c:choose>
     <c:when test="${pageInfo.pageSize==0}">
      <a href="${pageContext.request.contextPath}/user.do?pageNow=${pageInfo.pageNum}" rel="external nofollow" >下一页</a>
     </c:when>
     <c:when test="${pageInfo.pageNum + 1 < pageInfo.pageSize}">
      <a href="${pageContext.request.contextPath}/user.do?pageNow=${pageInfo.pageNum + 1}" rel="external nofollow" >下一页</a>
     </c:when>
     <c:when test="${pageInfo.pageNum + 1 >= pageInfo.pageSize}">
      <a href="${pageContext.request.contextPath}/user.do?pageNow=${pageInfo.pageSize}" rel="external nofollow" rel="external nofollow" rel="external nofollow" >下一页</a>
     </c:when>
    </c:choose>
    <c:choose>
     <c:when test="${pageInfo.pageSize==0}">
      <a href="${pageContext.request.contextPath}/user.do?pageNow=${pageInfo.pageSize}" rel="external nofollow" rel="external nofollow" rel="external nofollow" >尾页</a>
     </c:when>
     <c:otherwise>
      <a href="${pageContext.request.contextPath}/user.do?pageNow=${pageInfo.pageSize}" rel="external nofollow" rel="external nofollow" rel="external nofollow" >尾页</a>
     </c:otherwise>
    </c:choose>
   </div>
   <!-- 分页功能 End -->
  </td>

 </tr>
 <%--<tr>--%>
  <%--<td>${data.username}</td>--%>
  <%--<td>${data.password}</td>--%>
 <%--</tr>--%>
</table>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • java实现微信支付(服务端)

    java实现微信支付(服务端)

    这篇文章主要介绍了java实现微信支付,针对服务端进行代码编写,感兴趣的小伙伴们可以参考一下
    2015-12-12
  • Spring-AOP 静态正则表达式方法如何匹配切面

    Spring-AOP 静态正则表达式方法如何匹配切面

    这篇文章主要介绍了Spring-AOP 静态正则表达式方法如何匹配切面的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • 解决Spring事务@Transactional多层嵌套失效问题

    解决Spring事务@Transactional多层嵌套失效问题

    在使用Spring进行事务管理时,可能会遇到事务失效的问题,主要原因包括数据库不支持事务、方法访问级别不是public、未被Spring管理的Bean、当前类的方法内部调用以及配置的事务传播性不当等,解决事务失效的方法有使用声明式事务处理采用合适的事务传播行为
    2024-11-11
  • Java实现字符串与字节数组之间相互转换

    Java实现字符串与字节数组之间相互转换

    在Java编程中,字符串(String)和字节数组(byte[])之间的相互转换是非常常见的操作,这种转换在网络编程、文件处理、加密解密等场景中尤为重要,本文将详细介绍如何在Java中实现字符串与字节数组之间的相互转换,需要的朋友可以参考下
    2025-02-02
  • Java Scaner类详解_动力节点Java学院整理

    Java Scaner类详解_动力节点Java学院整理

    Java.util.Scanner是Java5.0的新特征,主要功能是简化文本扫描。下面通过本文给大家分享java scaner类相关知识,需要的朋友下吧
    2017-04-04
  • Java并发编程中使用Executors类创建和管理线程的用法

    Java并发编程中使用Executors类创建和管理线程的用法

    这篇文章主要介绍了Java并发编程中使用Executors类创建和管理线程的用法,文中举了用其启动线程和设置线程优先级的例子,需要的朋友可以参考下
    2016-03-03
  • SpringBoot使用Nacos进行application.yml配置管理

    SpringBoot使用Nacos进行application.yml配置管理

    Nacos是阿里巴巴开源的一个微服务配置管理和服务发现的解决方案,它提供了动态服务发现、配置管理和 服务管理平台,Nacos使用Raft协议保证配置的一致性,同时支持多种配置 格式,如properties、yaml等,本文介绍了SpringBoot使用Nacos进行application.yml配置管理
    2024-12-12
  • JAVA遍历Map集合的几种方法汇总

    JAVA遍历Map集合的几种方法汇总

    这篇文章主要给大家介绍了关于JAVA遍历Map集合的几种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • Java中对象的克隆详解

    Java中对象的克隆详解

    这篇文章主要介绍了Java中对象的克隆详解,Java中对象的复制分为浅复制与深复制的不同之处就在于深复制还会复制对象的引用对象,需要的朋友可以参考下
    2023-08-08
  • mybatis的dtd约束文件及配置文件xml自动提示操作

    mybatis的dtd约束文件及配置文件xml自动提示操作

    这篇文章主要介绍了mybatis的dtd约束文件及配置文件xml自动提示操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12

最新评论