转载:http://blog.csdn.net/u012728960/article/details/50791343

Mybatis分页插件-PageHelper的使用

怎样配置mybatis这里就不提了,我来说说我配置这个分页插件的过程吧。

下载JAR包

分页插件pagehelper.jar:

https://oss.sonatype.org/content/repositories/releases/com/github/pagehelper/pagehelper/ 
http://repo1.maven.org/maven2/com/github/pagehelper/pagehelper/ 
由于使用了sql解析工具,你还需要下载jsqlparser.jar

4.1.0及以后版本需要0.9.4版本

http://repo1.maven.org/maven2/com/github/jsqlparser/jsqlparser/0.9.4/ 
4.1.0以前版本需要0.9.1版本

http://repo1.maven.org/maven2/com/github/jsqlparser/jsqlparser/0.9.1/

一、首先,在spring-mybatis.xml中是这样配置:

  1. <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
  2. <property name="dataSource" ref="dataSource" />
  3. <property name="mapperLocations" value="classpath:com/sinyat/api/weather/mapping/*.xml" />
  4. <property name="typeAliasesPackage" value="com.sinyat.api.weather.model" />
  5. <property name="plugins">
  6. <array>
  7. <bean class="com.github.pagehelper.PageHelper">
  8. <property name="properties">
  9. <value>
  10. dialect=mysql
  11. </value>
  12. </property>
  13. </bean>
  14. </array>
  15. </property>
  16. </bean>

我是在spring里配置的,还可以在mybatis-config.xml里配置,有兴趣的话可以百度下。

二、需要分页,自然就还要一个查询了。用了PageHelper之后,查询语句就可以很简单了。

  1. <select id="selectAll" resultMap="BaseResultMap">
  2. select
  3. <include refid="Base_Column_List" />
  4. from citylist
  5. </select>

这是我的查询语句,查询城市列表。没有其他条件,就是查所有。当然,我这只是一个小的demo,没做那么麻烦,真正的使用,是需要条件查询的。 
现在来讲讲用了PageHelper之后的好处: 
那就是查询语句可以不用limit,但是就一点好处吗?自然不是。请接着往下看。

三、接口、实现类我就不再贴代码了,该怎么写还是怎么写,不需要传分页参数。然后是Controller:

  1. @RequestMapping("showcity")
  2. public ModelAndView showCityList(ModelAndView mv,
  3. @RequestParam(required=true,defaultValue="1") Integer page,
  4. @RequestParam(required=false,defaultValue="10") Integer pageSize){
  5. PageHelper.startPage(page, pageSize);
  6. List<CityList> list = cityListService.selectAll();
  7. PageInfo<CityList> p=new PageInfo<CityList>(list);
  8. //System.out.println(p.getList());
  9. mv.addObject("citylist", list);
  10. mv.addObject("page", p);
  11. mv.setViewName("weather/showCityList");
  12. return mv;
  13. }

可以看到,方法里有两个参数,前面也说了,这是一个demo,仅仅只是一个非常简单的分页效果。

  1. PageHelper.startPage(page, pageSize);

这段代码表示,程序开始分页了,page默认值是1,pageSize默认是10,意思是从第1页开始,每页显示10条记录。

PageInfo这个类是插件里的类,这个类里面的属性还是值得看一看:

  1. //当前页
  2. private int pageNum;
  3. //每页的数量
  4. private int pageSize;
  5. //当前页的数量
  6. private int size;
  7. //排序
  8. private String orderBy;
  9. //由于startRow和endRow不常用,这里说个具体的用法
  10. //可以在页面中"显示startRow到endRow 共size条数据"
  11. //当前页面第一个元素在数据库中的行号
  12. private int startRow;
  13. //当前页面最后一个元素在数据库中的行号
  14. private int endRow;
  15. //总记录数
  16. private long total;
  17. //总页数
  18. private int pages;
  19. //结果集
  20. private List<T> list;
  21. //第一页
  22. private int firstPage;
  23. //前一页
  24. private int prePage;
  25. //下一页
  26. private int nextPage;
  27. //最后一页
  28. private int lastPage;
  29. //是否为第一页
  30. private boolean isFirstPage = false;
  31. //是否为最后一页
  32. private boolean isLastPage = false;
  33. //是否有前一页
  34. private boolean hasPreviousPage = false;
  35. //是否有下一页
  36. private boolean hasNextPage = false;
  37. //导航页码数
  38. private int navigatePages;
  39. //所有导航页号
  40. private int[] navigatepageNums;

使用PageInfo这个类,你需要将查询出来的list放进去:

  1. PageInfo<CityList> p=new PageInfo<CityList>(list);

然后mv.addObject("page", p); 
这样在页面中就可以通过${page.nextPage}翻到下一页, 
${page.prePage}翻到上一页, 

下面这个是因为我没有进行判断,所以,第0页自然是什么都没有的。 
 
判断的话,在PageInfo里有对应的属性,比如:

  1. //是否有前一页
  2. private boolean hasPreviousPage = false;
  3. //是否有下一页
  4. private boolean hasNextPage = false;

好了,demo就是这些了。

下一个是通用Mapper,据说也是很不错的东西。

 

Mybatis分页插件-PageHelper的使用的更多相关文章

  1. Mybatis分页插件PageHelper的配置和使用方法

     Mybatis分页插件PageHelper的配置和使用方法 前言 在web开发过程中涉及到表格时,例如dataTable,就会产生分页的需求,通常我们将分页方式分为两种:前端分页和后端分页. 前端分 ...

  2. Mybatis分页插件PageHelper使用

    一. Mybatis分页插件PageHelper使用  1.不使用插件如何分页: 使用mybatis实现: 1)接口: List<Student> selectStudent(Map< ...

  3. Java SSM框架之MyBatis3(三)Mybatis分页插件PageHelper

    引言 对于使用Mybatis时,最头痛的就是写分页,需要先写一个查询count的select语句,然后再写一个真正分页查询的语句,当查询条件多了之后,会发现真不想花双倍的时间写count和select ...

  4. Mybatis学习---Mybatis分页插件 - PageHelper

    1. Mybatis分页插件 - PageHelper说明 如果你也在用Mybatis,建议尝试该分页插件,这个一定是最方便使用的分页插件. 该插件目前支持Oracle,Mysql,MariaDB,S ...

  5. Mybatis分页插件PageHelper的实现

    Mybatis分页插件PageHelper的实现 前言 分页这个概念在做web网站的时候很多都会碰到 说它简单吧 其实也简单 小型的网站,完全可以自己写一个,首先查出数据库总条数,然后按照分页大小分为 ...

  6. 基于Mybatis分页插件PageHelper

    基于Mybatis分页插件PageHelper 1.分页插件使用 1.POM依赖 PageHelper的依赖如下.需要新的版本可以去maven上自行选择 <!-- PageHelper 插件分页 ...

  7. (转)淘淘商城系列——MyBatis分页插件(PageHelper)的使用以及商品列表展示

    http://blog.csdn.net/yerenyuan_pku/article/details/72774381 上文我们实现了展示后台页面的功能,而本文我们实现的主要功能是展示商品列表,大家要 ...

  8. springmvc mybatis 分页插件 pagehelper

    springmvc mybatis 分页插件 pagehelper 下载地址:pagehelper 4.2.1 , jsqlparser 0.9.5 https://github.com/pagehe ...

  9. MyBatis 分页插件PageHelper 后台报错

    今天遇到一个问题,使用MyBatis 分页插件PageHelper 进行排序分页后,能正常返回正确的结果,但后台却一直在报错 net.sf.jsqlparser.parser.ParseExcepti ...

随机推荐

  1. Leetcode37--->Sudoku Solver(填充数独)

    题目: 给定一个不完整的数独,要求填充好数独:最初给出的数独是有效的,且假设一定有答案: 举例: A sudoku puzzle... 解题思路: 该题与青蛙走迷宫问题很相似,都是用深度优先: 代码如 ...

  2. php生成Exeple表demo

    <?php require "./PHPExcel.php"; $dir=dirname(__FILE__); $objPHPExcel=new PHPExcel(); $o ...

  3. xml ,html,xhtml

    html,xhtml和xml的定义: 1.html即是超文本标记语言(Hyper Text Markup Language),是最早写网页的语言,但是由于时间早,规范不是很好,大小写混写且编码不规范: ...

  4. [uiautomator篇] 使用uiautomator需要导入uiautomator库

    1 修改依赖文件:build/gradle( 是在app目录下)而不是和app同级目录的build/gradle androidTestCompile 'com.android.support.tes ...

  5. 在springmvc中使用@PathVariable时,应该注意点什么?

    导读:近来在做库存调剂系统时,我从前台到后台的传值方式,主要包括:1个,用@PathVariable或者@RequestParam从路径取:大于一个,用于更新或者添加操作的,我用的是表单实体传到后台: ...

  6. [luoguP1251] 餐巾计划问题(费用流)

    传送门 模型 网络优化问题,用最小费用最大流解决. 实现 把每天分为二分图两个集合中的顶点Xi,Yi,建立附加源S汇T. 1.从S向每个Xi连一条容量为ri,费用为0的有向边. 2.从每个Yi向T连一 ...

  7. Python Base One

    //this is my first day to study python, in order to review, every day i will make notes (2016/7/31) ...

  8. FZOJ Problem 2103 Bin & Jing in wonderland

                                                                                                        ...

  9. P1340 送礼物

    时间: 1000ms / 空间: 131072KiB / Java类名: Main 描述 作为惩罚,GY被遣送去帮助某神牛给女生送礼物(GY:貌似是个好差事)但是在GY看到礼物之后,他就不这么认为了. ...

  10. 【BZOJ4472】salesman(树形DP)

    题意: 给定一颗有点权的树,每个树上的节点最多能走到lim[u]次,求一条路径,使路径上的点权和最大,每个节点上的点权如果走了多次只能算一次.还要求方案是否唯一. 思路:每个点只能取lim[u]-1个 ...