ssm框架中使用PageHelper

来源:互联网 发布:显示器品牌知乎 编辑:程序博客网 时间:2024/06/15 23:57

在ssm框架中使用PageHelper

PageHelper是一个非常好用的Mybatis插件,如果有需要用到分页功能,并且也是用maven作为构建项目工具的话,它一定是个不错的选择。

在pom中添加依赖

<!--pageHelper分页-->        <dependency>            <groupId>com.github.pagehelper</groupId>            <artifactId>pagehelper</artifactId>            <version>4.0.0</version>        </dependency>

在mybatis配置xml中添加插件

<plugins>        <!-- com.github.pagehelper为PageHelper类所在包名 -->        <plugin interceptor="com.github.pagehelper.PageHelper">            <property name="dialect" value="mysql"/>            <!-- 该参数默认为false -->            <!-- 设置为true时,会将RowBounds第一个参数offset当成pageNum页码使用 -->            <!-- 和startPage中的pageNum效果一样-->            <property name="offsetAsPageNum" value="true"/>            <!-- 该参数默认为false -->            <!-- 设置为true时,使用RowBounds分页会进行count查询 -->            <property name="rowBoundsWithCount" value="true"/>            <!-- 设置为true时,如果pageSize=0或者RowBounds.limit = 0就会查询出全部的结果 -->            <!-- (相当于没有执行分页查询,但是返回结果仍然是Page类型)-->            <property name="pageSizeZero" value="true"/>            <!-- 3.3.0版本可用 - 分页参数合理化,默认false禁用 -->            <!-- 启用合理化时,如果pageNum<1会查询第一页,如果pageNum>pages会查询最后一页 -->            <!-- 禁用合理化时,如果pageNum<1或pageNum>pages会返回空数据 -->            <property name="reasonable" value="false"/>            <!-- 3.5.0版本可用 - 为了支持startPage(Object params)方法 -->            <!-- 增加了一个`params`参数来配置参数映射,用于从Map或ServletRequest中取值 -->            <!-- 可以配置pageNum,pageSize,count,pageSizeZero,reasonable,不配置映射的用默认值 -->            <!-- 不理解该含义的前提下,不要随便复制该配置 -->            <property name="params" value="pageNum=start;pageSize=limit;"/>        </plugin>    </plugins>

在Spring配置中配置sqlSessionFactory的时候引入配置文件


 <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">        <property name="dataSource" ref="dataSource" />        <property name="configLocation" value="classpath:conf/mybatis/mybatis.xml" />        <property name="mapperLocations" value="classpath:mapper/*.xml" />    </bean>

最后,如何在业务中使用
分页插件支持多种调用方式,这里介绍比较推荐使用的Mapper接口方式的调用

/**condition为分页条件     pageNum表示页数    pageSize表示一页多少条数据*/ PageHelper.startPage(condition.getPageNum(),   condition.getPageSize()); List<Item> itemMapper.getItemByCondition(ItemListCondition condition);

OK,以上就是对smm中使用PageHelper的一个简单介绍。
参考资料:
http://git.oschina.net/free/Mybatis_PageHelper

0 0
原创粉丝点击