如何在SpringMVC中使用MyBatis与MySQL实现一个分页功能

这篇文章将为大家详细讲解有关如何在Spring MVC中使用MyBatis与MySQL实现一个分页功能,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

公司主营业务:成都网站建设、成都网站制作、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联推出麒麟免费做网站回馈大家。

方法如下: 

首先写一个分页的工具类,定义当前页数,总页数,每页显示多少等属性。

/** 
 * 分页 工具类 
 */ 
public class Page implements Serializable { 
 private static final long serialVersionUID = -2213069645383858323L; 
 private int pageNow = 1; // 当前页数 
 private int pageSize = 4; // 每页显示记录的条数 
 private int totalCount; // 总的记录条数 
 private int totalPageCount; // 总的页数 
 private int startPos; // 开始位置,从0开始 
 private boolean hasFirst;// 是否有首页 
 private boolean hasPre;// 是否有前一页 
 private boolean hasNext;// 是否有下一页 
 private boolean hasLast;// 是否有最后一页 
 /** 
  * 通过构造函数 传入 总记录数 和 当前页 
  * @param totalCount 
  * @param pageNow 
  */ 
 public Page(int totalCount, int pageNow) { 
  this.totalCount = totalCount; 
  this.pageNow = pageNow; 
 } 
 /** 
  * 取得总页数,总页数=总记录数/总页数 
  * @return 
  */ 
 public int getTotalPageCount() { 
  totalPageCount = getTotalCount() / getPageSize(); 
  return (totalCount % pageSize == 0) ? totalPageCount 
    : totalPageCount + 1; 
 } 
 public void setTotalPageCount(int totalPageCount) { 
  this.totalPageCount = totalPageCount; 
 } 
 public int getPageNow() { 
  return pageNow; 
 } 
 public void setPageNow(int pageNow) { 
  this.pageNow = pageNow; 
 } 
 public int getPageSize() { 
  return pageSize; 
 } 
 public void setPageSize(int pageSize) { 
  this.pageSize = pageSize; 
 } 
 public int getTotalCount() { 
  return totalCount; 
 } 
 public void setTotalCount(int totalCount) { 
  this.totalCount = totalCount; 
 } 
 /** 
  * 取得选择记录的初始位置 
  * @return 
  */ 
 public int getStartPos() { 
  return (pageNow - 1) * pageSize; 
 } 
 public void setStartPos(int startPos) { 
  this.startPos = startPos; 
 } 
 /** 
  * 是否是第一页 
  * @return 
  */ 
 public boolean isHasFirst() { 
  return (pageNow == 1) ? false : true; 
 } 
 public void setHasFirst(boolean hasFirst) { 
  this.hasFirst = hasFirst; 
 } 
 /** 
  * 是否有首页 
  * @return 
  */ 
 public boolean isHasPre() { 
  // 如果有首页就有前一页,因为有首页就不是第一页 
  return isHasFirst() ? true : false; 
 } 
 public void setHasPre(boolean hasPre) { 
  this.hasPre = hasPre; 
 } 
 /** 
  * 是否有下一页 
  * @return 
  */ 
 public boolean isHasNext() { 
  // 如果有尾页就有下一页,因为有尾页表明不是最后一页 
  return isHasLast() ? true : false; 
 } 
 
 public void setHasNext(boolean hasNext) { 
  this.hasNext = hasNext; 
 } 
 /** 
  * 是否有尾页 
  * @return 
  */ 
 public boolean isHasLast() { 
  // 如果不是最后一页就有尾页 
  return (pageNow == getTotalCount()) ? false : true; 
 } 
 
 public void setHasLast(boolean hasLast) { 
  this.hasLast = hasLast; 
 } 
} 

接着Mapper接口中定义分类的方法

如何在Spring MVC中使用MyBatis与MySQL实现一个分页功能

传入两个参数,分别是开始页和每页显示记录的条数。 

Mapper的映射文件中的SQL分页语句

 

接着在控制类(Controller)中查询商品,同时进行分页。

查询商品方法

/** 
  * 查询商品信息,实现分页 
  * @param goods 
  * @return 
  * @throws Exception 
  */ 
 @RequestMapping("/queryPages") 
 public String queryPages(HttpServletRequest request, Model model) throws Exception { 
  String pageNow = request.getParameter("pageNow"); 
  Page page = null; 
  List goods = new ArrayList(); 
  int totalCount = (int) service.getGoodsCount(1); 
  if (pageNow != null) { 
   page = new Page(totalCount, Integer.parseInt(pageNow)); 
   goods = this.service.findPages(page.getStartPos(), page.getPageSize()); 
  } else { 
   page = new Page(totalCount, 1); 
   goods = this.service.findPages(page.getStartPos(), page.getPageSize()); 
  } 
  model.addAttribute("goods_list", goods); 
  model.addAttribute("page", page); 
  return "goods/FenYeTest"; 
 } 

这里需要注意一下,遍历商品时没有点击页数,所以当前页默认是空的,这里要在方法里面进行判断,如果pageNow为空,传一个1到构造函数,否则会报空指针。

最后,在jsp页面显示查询的商品列表,同时实现点击上一页,下一页,首页,尾页等常见分页中的操作

<%@ page language="java" contentType="text/html; charset=UTF-8" 
 pageEncoding="UTF-8"%> 
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> 
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt"%> 
 
 
 
 
商品查询列表 
 
 
 
  
   
选择 商品名称 商品价格 生产数量 商品类别 商品图片 商品信息 操作
${item.id} ${item.name } ${item.price } ${item.num } ${item.classInfo.class_name } 商品图片 ${item.des } 修改 删除

关于如何在Spring MVC中使用MyBatis与MySQL实现一个分页功能就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。


名称栏目:如何在SpringMVC中使用MyBatis与MySQL实现一个分页功能
文章地址:http://csdahua.cn/article/pggsce.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流