PageHelper在SSM框架中使用

1 PageHelper介绍

PageHelper是国内非常优秀的一款开源的mybatis分页插件,它支持基本主流与常用的数据库,例如mysql、 oracle、mariaDB、DB2、SQLite、Hsqldb等。
本项目在 github 的项目地址:https://github.com/pagehelper/Mybatis-PageHelper 本项目在 gitosc 的项目地址:http://git.oschina.net/free/Mybatis_PageHelper

2 PageHelper使用

2.1 集成

引入分页插件有下面2种方式,推荐使用 Maven 方式。

2.1.1 引入 Jar 包

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

2.1.2 使用 Maven

在 pom.xml 中添加如下依赖:

 <dependency> 
 	<groupId>com.github.pagehelper</groupId> 	
 	<artifactId>pagehelper</artifactId>
 	<version>最新版本</version>
</dependency>

2. 2 配置

特别注意,新版拦截器是 com.github.pagehelper.PageInterceptor 。 com.github.pagehelper.PageHelper 现
在是一个特殊的 dialect 实现类,是分页插件的默认实现类,提供了和以前相同的用法。

2.2.1. 在 MyBatis 配置 xml 中配置拦截器插件

 <!-- plugins在配置文件中的位置必须符合要求,否则会报错,顺序如下: properties?, settings?,
typeAliases?, typeHandlers?, objectFactory?,objectWrapperFactory?,
plugins?,
environments?, databaseIdProvider?, mappers?
-->
<plugins>
<!-- com.github.pagehelper为PageHelper类所在包名 -->
<plugin interceptor="com.github.pagehelper.PageInterceptor">
<!-- 使用下面的方式配置参数,后面会有所有的参数介绍 -->
        <property name="param1" value="value1"/>
    </plugin>
</plugins>

2.2.2. 在 Spring 配置文件中配置拦截器插件

使用 spring 的属性配置方式,可以使用 plugins 属性像下面这样配置:

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <!-- 注意其他配置 -->
<property name="plugins">
    <array>
      <bean class="com.github.pagehelper.PageInterceptor">
<property name="properties"> <!--使用下面的方式配置参数,一行配置一个 --> <value>
            params=value1
          </value>
        </property>
      </bean>
    </array>
  </property>
</bean>

2.3 分页插件参数介绍

          1)、  helperDialect:分页插件会自动检测当前的数据库链接,自动选择合适的分页方式。 你可以配置helperDialect属性来指定分页插件使用哪种方言。配置时,可以使用下面的缩写值:    

    oracle,mysql,mariadb,sqlite,hsqldb,postgresql,db2,sqlserver,informix,h2,sqlserver2012,derby 

    特别注意:使用 SqlServer2012 数据库时,需要手动指定为sqlserver2012,否则会使用 SqlServer2005 的方式进行分页。

     你也可以实现AbstractHelperDialect,然后配置该属性为实现类的全限定名称即可使用自定义的实现方法。

           2)、offsetAsPageNum:默认值为false,该参数对使用RowBounds作为分页参数时有效。 当该参数设置为true时,会将RowBounds中的offset参数当成pageNum使用,可以用页码和页面大小两个参数进行分页。

           3)、rowBoundsWithCount:默认值为false,该参数对使用RowBounds作为分页参数时有效。 当该参数设置为true时,使用RowBounds分页会进行 count 查询。

           4)、pageSizeZero:默认值为false,当该参数设置为true时,如果pageSize=0或者RowBounds.limit = 0就会查询出全部的结果(相当于没有执行分页查询,但是返回结果仍然是Page类型)。

           5)、reasonable:分页合理化参数,默认值为false。当该参数设置为true时,pageNum<=0时会查询第一页,pageNum>pages(超过总数时),会查询最后一页。默认false时,直接根据参数进行查询。

           6)、params:为了支持startPage(Object params)方法,增加了该参数来配置参数映射,用于从对象中根据属性名取值, 可以配置pageNum,pageSize,count,pageSizeZero,reasonable,不配置映射的用默认值, 默认值为:pageNum=pageNum;pageSize=pageSize;count=countSql;reasonable=reasonable;pageSizeZero=pageSizeZero。

           7)、supportMethodsArguments:支持通过 Mapper 接口参数来传递分页参数,默认值false,分页插件会从查询方法的参数值中,自动根据上面params配置的字段中取值,查找到合适的值时就会自动分页。 使用方法可以参考测试代码中的com.github.pagehelper.test.basic包下的ArgumentsMapTest和ArgumentsObjTest。

           8)、autoRuntimeDialect:默认值为false。设置为true时,允许在运行时根据多数据源自动识别对应方言的分页 (不支持自动选择sqlserver2012,只能使用sqlserver)。

           9)、closeConn:默认值为true。当使用运行时动态数据源或没有设置helperDialect属性自动获取数据库类型时,会自动获取一个数据库连接, 通过该属性来设置是否关闭获取的这个连接,默认true关闭,设置为false后,不会关闭获取的连接,这个参数的设置要根据自己选择的数据源来决定。

2.4.基本使用

PageHelper的基本使用有6种,大家可以查看文档,最常用的有两种

2.4.1. RowBounds方式的调用(了解)

List<Country> list = sqlSession.selectList("x.y.selectIf", null, new RowBounds(1, 10));

使用这种调用方式时,你可以使用RowBounds参数进行分页,这种方式侵入性最小,我们可以看到,通过
RowBounds方式调用只是使用了这个参数,并没有增加其他任何内容。 分页插件检测到使用了RowBounds参数时,就会对该查询进行物理分页。 关于这种方式的调用,有两个特殊的参数是针对 RowBounds 的,你可以参看上面的分页插件参数介绍 注:不只有命名空间方式可以用RowBounds,使用接口的时候也可以增加RowBounds参数,例如:

//这种情况下也会进行物理分页查询
List<Country> selectAll(RowBounds rowBounds);

注意: 由于默认情况下的 RowBounds 无法获取查询总数,分页插件提供了一个继承自 RowBounds 的 PageRowBounds ,这个对象中增加了 total 属性,执行分页查询后,可以从该属性得到查询总数。

2.4.2. PageHelper.startPage 静态方法调用(重点)

这种方式是我们要掌握的 在你需要进行分页的 MyBatis 查询方法前调用PageHelper.startPage 静态方法即可,紧
跟在这个方法后的第一个MyBatis 查询方法会被进行分页。

 //获取第1页,10条内容,默认查询总数count 
 PageHelper.startPage(1, 10); 
 //紧跟着的第一个select方法会被分页
 List<Country> list = countryMapper.selectIf(1);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 SSM (Spring + SpringMVC + MyBatis) 框架,你可以使用 MyBatis 的分页插件来实现分页查询。 首先,你需要在 MyBatis 的配置文件启用分页插件: ``` <plugins> <plugin interceptor="org.mybatis.generator.plugins.RowBoundsPlugin"/> </plugins> ``` 然后,在你的 Mapper 接口声明分页查询方法,并使用 MyBatis 的 RowBounds 类来进行分页: ```java public interface UserMapper { List<User> selectByPage(RowBounds rowBounds); } ``` 在你的 Service 层,你可以调用 Mapper 接口的分页查询方法,并传入 RowBounds 对象来实现分页: ```java public class UserService { @Autowired private UserMapper userMapper; public List<User> getUsersByPage(int pageNum, int pageSize) { int offset = (pageNum - 1) * pageSize; RowBounds rowBounds = new RowBounds(offset, pageSize); return userMapper.selectByPage(rowBounds); } } ``` 在你的 Controller 层,你可以调用 Service 层的分页查询方法,并将分页参数作为方法的参数传入: ```java public class UserController { @Autowired private UserService userService; @RequestMapping("/users") public List<User> getUsers(int pageNum, int pageSize) { return userService.getUsersByPage(pageNum, pageSize); } } ``` 你还可以使用第三方的分页插件,比如 PageHelper,它提供了更为简单的分页查询方式。 ### 回答2: 在SSM框架,实现分页查询一般需要以下几个步骤: 1. 在数据库创建对应的数据表,保存需要查询的数据。 2. 在Spring配置文件配置数据源,设置数据库连接信息。 3. 创建实体类(POJO),并映射到数据库的表结构。使用注解指定表名、字段名、主键等信息。 4. 创建数据访问层接口(DAO),定义分页查询的方法。使用注解或者XML文件进行方法的映射。 5. 在数据访问层实现类,实现分页查询的方法。使用MyBatis提供的分页插件PageHelper完成分页查询。在方法设置分页参数,如当前页码和每页显示的数量,并调用对应的查询方法。 6. 创建业务逻辑层(Service),调用数据访问层的方法进行分页查询。 7. 在控制层(Controller)接收分页参数,并调用业务逻辑层的方法进行分页查询。将查询结果封装成Page对象,并传递给前端页面。 8. 在前端页面使用分页插件(如Bootstrap的分页插件或jQuery的分页插件)展示分页信息和查询结果。 总结:通过以上步骤,我们可以在SSM框架实现分页查询。使用PageHelper插件可以简化分页查询的操作,提高开发效率。在分页查询时,需要注意设置分页参数,并合理利用数据库的索引等优化查询性能。 ### 回答3: 在SSM框架,可以使用PageHelper插件实现分页查询。 首先,需要在pom.xml文件添加PageHelper的依赖: ``` <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper</artifactId> <version>版本号</version> </dependency> ``` 然后,在Spring配置文件配置PageHelper的插件: ``` <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <!-- 配置数据源等其他相关属性 --> <property name="plugins"> <array> <bean class="com.github.pagehelper.PageInterceptor"> <property name="properties"> <!-- 设置数据库方言为MySQL --> <value>dialect=mysql</value> </property> </bean> </array> </property> </bean> ``` 接下来,在需要进行分页查询的方法使用PageHelper的startPage方法来设置分页参数: ``` PageHelper.startPage(页码, 每页显示数量); ``` 然后,执行查询操作,返回的结果将变为一个分页对象,可以通过该对象获取相关的分页信息和查询结果,比如: ``` List<SomeEntity> list = someMapper.selectByExample(example); PageInfo pageInfo = new PageInfo(list); ``` 在页面上展示分页信息,可以使用PageInfo提供的相关方法,例如获取总记录数、总页数、当前页码、每页显示数量等: ``` pageInfo.getTotal() // 获取总记录数 pageInfo.getPages() // 获取总页数 pageInfo.getPageNum() // 获取当前页码 pageInfo.getPageSize() // 获取每页显示数量 ``` 同时,查询结果也包含在PageInfo对象的列表: ``` List<SomeEntity> resultList = pageInfo.getList(); ``` 通过以上步骤,就可以在SSM框架实现分页查询操作了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值