【MyBatis】MyBatis分页插件PageHelper的使用

转载 2018年04月16日 17:11:01
这篇博文主要来总结下如何使用PageHelper。 
  我们知道,在MySQL中,分页的sql是使用limit来做,如果我们自己写sql,那分页肯定是没有任何问题的。但是一旦model多了起来,复杂了起来,我们很自然的想到使用mybatis的逆向工程来生成相应的po和mapper,但是同时也会带来弊端,比如这里的分页问题就不好解决了。 
  可能有人会说,我可以修改生成的文件,没错,这是可行的,但是一般我们通过逆向工程生成的文件,都不会去动它,所以这个时候,就需要使用分页插件来解决了。在介绍如何使用这个分页插件之前,先介绍一下mybatis中的插件是如何工作的,主要作用在哪个环节。我之前有写过一篇mybatis的一篇入门文章:宏观上把我mybatis框架。里面有张mybatis的工作原理图,为了方便叙述,我把图也放在这: 

这里写图片描述 
  从图中可以看出,mybatis中首先要在配置文件中配置一些东西,然后根据这些配置去创建一个会话工厂,再根据会话工厂创建会话,会话发出操作数据库的sql语句,然后通过执行器操作数据,再使用mappedStatement对数据进行封装,这就是整个mybatis框架的执行情况。那么mybatis的插件作用在哪一环节呢?它主要作用在Executor执行器与mappedeStatement之间,也就是说mybatis可以在插件中获得要执行的sql语句,在sql语句中添加limit语句,然后再去对sql进行封装,从而可以实现分页处理。 
  搞清楚了分页插件的执行情况,下面来总结下mybatis中PageHelper的使用。

1. 需要引入PageHelper的jar包

  如果没有使用maven,那直接把jar包导入到lib文件夹下即可,这个PageHelper插件在github上有开源,地址为:https://github.com/pagehelper/Mybatis-PageHelper/tree/master/src/main/java/com/github/pagehelper。 
如果使用了maven,那么只要在pom.xml中引入该插件即可,引入如下:

 

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

 

 

2. 在mybatis的全局配置文件SqlMapConfig.xml中配置该插件

复制代码
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <!-- 配置分页插件 -->
    <plugins>
        <plugin interceptor="com.github.pagehelper.PageHelper">
            <!-- 设置数据库类型 Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL六种数据库-->        
            <property name="dialect" value="mysql"/>
        </plugin>
    </plugins>

</configuration>
复制代码

3. 在执行sql前添加插件,完成分页功能

  在查询的sql语句执行之前,添加一行代码PageHelper.startPage(1, 10);第一个参数表示第几页,第二个参数表示每页显示的记录数。这样在执行sql后就会将记录按照语句中设置的那样进行分页。如果需要获取总记录数的话,需要PageInfo类的对象,这个对象可以获取总记录数,下面看下测试的代码。

 

复制代码
public class TestPageHelper {

    @Test
    public void testPageHelper() {
        // 创建一个spring容器
        ApplicationContext context = new ClassPathXmlApplicationContext("classpath:spring/applicationContext-*");
        // 从spring容器中获取mapper代理对象
        TbItemMapper mapper = context.getBean(TbItemMapper.class);
        // 执行查询并分页,TbItemExample是逆向工程自动生成的,用来进行条件查询,这里不设置则表示无条件
        TbItemExample example = new TbItemExample();
        //分页处理,显示第一页的10条数据
        PageHelper.startPage(1, 10);
        List<TbItem> list = mapper.selectByExample(example);//查询
        // 取商品列表
        for(TbItem item : list) {
            System.out.println(item.getTitle());
        }
        // 取分页信息
        PageInfo<TbItem> pageInfo = new PageInfo<TbItem>(list);
        long total = pageInfo.getTotal(); //获取总记录数
        System.out.println("共有商品信息:" + total);
    }
}
复制代码

 

看下执行的结果:

夏普(SHARP)LCD-46DS40A 46英寸 日本原装液晶面板 智能全高清液晶电视 
飞利浦 老人手机 (X2560) 深情蓝 移动联通2G手机 双卡双待 
中兴 U288 珠光白 移动3G手机 
三星 SCH-W899 亮金色 电信3G手机 双卡双待双通 
飞利浦 老人手机 (X2560) 喜庆红 移动联通2G手机 双卡双待 
飞利浦 老人手机 (X2560) 硬朗黑 移动联通2G手机 双卡双待 
三星 Galaxy S4 (I9500)16G版 皓月白 联通3G手机 
三星 Galaxy S4 (I9500) 16G版 星空黑 联通3G手机 
三星 I8552 白色 联通3G手机 双卡双待 
长虹(CHANGHONG) 3D51C1080i 51英寸 快门式3D智能Android 电视(黑色) 
共有商品信息:3096

     可以看到,只显示出了10条数据,但是我总共有3096条数据,如果将参数改成(2,10),那么就会显示第二页不同的10条数据,在这就不测试了。这说明PageHelper插件可以帮助我们实现分页功能,例如EasyUI中就会传到后台分页参数信息,后台就可以根据参数获取分页数据等等。 
  正如前面所说,这个PageHelper其实也有缺点,因为它对逆向工程生成的代码支持不好,不能对有查询条件的查询分页,会抛异常,上面是无条件查询的。当然,我们自己可以修改这个PageHelper插件,使其支持条件查询,当然,我是修改不了的……网上有修改过后的PageHelper插件,可以支持条件查询,相对来说就比较强大了,可以在自己的工程中依赖修改过后的分页插件进行开发。

mybatis pagehelper分页插件使用

mybatis pagehelper
  • qq_26790807
  • qq_26790807
  • 2017年03月16日 18:44
  • 7327

mybatis框架---分页插件PageHelper的使用方法

以前自己写分页时,需要自己写sql语句,并且进行分页判断之后 目前Mybatis提供了分页插件,使用起来非常简便 一、首先,在spring-mybatis.xml中是这样配置:(数据源,分页拦截器...
  • happyAliceYu
  • happyAliceYu
  • 2017年03月13日 15:25
  • 10979

Mybatis插件原理和PageHelper结合实战分页插件

今天和大家分享下mybatis的一个分页插件PageHelper,在讲解PageHelper之前我们需要先了解下mybatis的插件原理。PageHelper 的官方网站:https://git...
  • fengqilove520
  • fengqilove520
  • 2016年12月30日 13:32
  • 1324

关于Spring+mybatis+PageHelper分页插件PageHelper的使用策略

把插件jar包导入项目(具体上篇有介绍http://blog.csdn.net/qq_33624284/article/details/72821811) spring-mybatis.xml文件中配...
  • qq_33624284
  • qq_33624284
  • 2017年06月01日 10:33
  • 13938

Mybatis使用pageHelper分页插件原理

首先在Mybatis的配置文件 SqlMapConfig.xml中配置PageHelper插件 xml version="1.0" encoding="UTF-8" ?> DOCTYPE c...
  • jaryle
  • jaryle
  • 2016年08月25日 16:24
  • 18587

Spring Boot+Mybatis+Pagehelper分页

Spring Boot 集成MyBatis和Pagehelper分页插件 mybatis-spring-boot-starter依赖树如下: pom配置 project xmlns="http...
  • xiaolyuh123
  • xiaolyuh123
  • 2017年06月20日 19:00
  • 21384

【MyBatis】MyBatis分页插件PageHelper的使用

好多天没写博客了,因为最近在实习,大部分时间在熟悉实习相关的东西,也没有怎么学习新的东西,这周末学习了MyBatis的一个分页插件PageHelper,虽然没有那么的强大(我在最后会说明它的缺点),但...
  • eson_15
  • eson_15
  • 2016年08月21日 23:14
  • 30008

spring-boot 集成mybatis的分页插件PageHelper和Generator (番外)

分页插件PageHelper 参看了pagehelper-spring-boot,使用起来非常放方便。 添加maven依赖 根据上面地址中的说明,只需要添加如下依赖,并且可以不再mybatis的依赖 ...
  • zl18310999566
  • zl18310999566
  • 2017年01月07日 10:28
  • 25083

Spring Boot系列教程十一: Mybatis使用分页插件PageHelper

一.前言 上篇博客中介绍了spring boot集成mybatis的方法,基于上篇文章这里主要介绍如何使用分页插件PageHelper。在MyBatis中提供了拦截器接口,我们可以使用PageHelp...
  • woniu211111
  • woniu211111
  • 2017年01月15日 15:55
  • 23002

mybatis 分页插件pagehelper集成及使用

1.环境及导入的jar mybatis版本3.3.1(建议使用3.3以上的版本) pagehelper-4.2.1插件及依赖jar(附:jar下载地址) 2.创建mybatis配置文件:mybatis...
  • wyd1610712520
  • wyd1610712520
  • 2016年12月15日 16:21
  • 4696
收藏助手
不良信息举报
您举报文章:【MyBatis】MyBatis分页插件PageHelper的使用
举报原因:
原因补充:

(最多只允许输入30个字)