mybatis分页插件pageHelper详解及简单实例
作者:lqh 时间:2024-01-19 17:35:25
mybatis分页插件pageHelper详解及简单实例
工作的框架spring springmvc mybatis3
首先使用分页插件必须先引入maven依赖,在pom.xml中添加如下
<!-- 分页助手 -->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>3.7.5</version>
</dependency>
其次需要在配置文件中添加配置,有两种方式
1,新建mybatis-config.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>
<!-- com.github.pagehelper为PageHelper类所在包名 -->
<plugin interceptor="com.github.pagehelper.PageHelper">
<!-- 数据库方言 -->
<property name="dialect" value="MySQL"/>
<!-- 设置为true时,使用RowBounds分页会进行count查询 会去查询出总数 -->
<property name="rowBoundsWithCount" value="true"/>
</plugin>
</plugins>
</configuration>
在spring-mybatis.xml中添加一个bean属性
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
加载全局的配置文件
<property name="configLocation" value="classpath:mybatis-config.xml"></property>
配置mapper的扫描,找到所有的mapper.xml映射文件。
<property name="mapperLocations" value="classpath:com/lyitong/mapping/*.xml"></property>
备注:如果你的mybatis-config.xml配置文件开启了如下别名配置:
<typeAliases>
<!-- javabean 的首字母小写的非限定类名来作为它的别名(其实别名是不去分大小写的)。也可在javabean 加上注解@Alias 来自定义别名, 例如: @Alias(student) -->
<package name="com.lyt.usermanage.mapper"/>
</typeAliases>
那么你的spring和mybatis整合文件就得加上相应的属性,否则会造成mybatis配置文件加载不成功报异常,如下:
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<!-- 加载全局的配置文件 -->
<property name="configLocation" value="classpath:mybatis/mybatis-config.xml"></property>
<!-- 配置mapper的扫描,找到所有的mapper.xml映射文件。 -->
<property name="mapperLocations" value="classpath:com/lyt/usermanage/mapper/*.xml"></property>
<!-- 配置类型别名 -->
<property name="typeAliasesPackage" value="classpath:com/lyt/usermanage/pojo/*"></property>
</bean>
相比于上面的配置我们这里多了一步
<property name="typeAliasesPackage" value="classpath:com/lyt/usermanage/pojo/*"></property>
配置的时候要注意mybatis配置文件和spring-mybatis整合文件的属性要统一。
2.如上操作配置完成,下面第二种方法
直接在spring-mybatis.xml中配置如下属性
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="mapperLocations" value="classpath:com/lyitong/mapping/*.xml"></property>
<!-- pageHelper 分页插件 -->
<property name="plugins">
<array>
<bean class="com.github.pagehelper.PageHelper">
<property name="properties">
<value>
dialect=mysql
rowBoundsWithCount=true
</value>
</property>
</bean>
</array>
</property>
</bean>
配置文件加载好之后,就可以直接使用,具体使用代码如下:
PageHelper.startPage(Integer.parseInt(currentPage), Integer.parseInt(pageSize));
List<LytBbsTz> publishTz = bbsTzDao.getPublishTz(userId);
PageInfo<LytBbsTz> info = new PageInfo<LytBbsTz>(publishTz);
map.put("status", 1);
map.put("tzList", info.getList());
return map;
前台需要传入的参数是当前页和页面显示数目,当然页面显示数目也可以后台规定,一般在接收参数时最好加上默认配置如下:
@RequestParam(defaultValue="1",value="currentPage")String currentPage, @RequestParam(defaultValue="10",value="pageSize")String pageSize
这是如果接收参数为空字符串时它自身默认显示的页面和条数,这个可以自己规定
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
来源:http://blog.csdn.net/smile_miracle/article/details/53185655
标签:mybatis,分页插件,pageHelper
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Vue父子组件传值的一些坑
2024-04-28 09:30:57
![](https://img.aspxhome.com/file/2023/2/132942_0s.png)
使用git上传到码云分支的实现
2022-04-01 06:05:06
![](https://img.aspxhome.com/file/2023/5/132465_0s.png)
python能否java成为主流语言吗
2022-10-16 18:34:11
python实现键盘输入的实操方法
2022-07-25 19:18:25
![](https://img.aspxhome.com/file/2023/5/121485_0s.jpg)
python 多线程将大文件分开下载后在合并的实例
2023-05-12 06:27:36
mysql5.x升级到mysql5.7后导入之前数据库date出错的快速解决方法
2024-01-22 10:09:17
MySql树形结构(多级菜单)查询设计方案
2024-01-18 15:35:42
![](https://img.aspxhome.com/file/2023/4/116794_0s.png)
Python图像处理库crop()函数 thumbnail方法使用详解
2022-12-26 05:57:46
python实现windows下文件备份脚本
2021-05-06 06:32:41
golang使用sort接口实现排序示例
2024-02-21 09:42:11
Python基于多线程操作数据库相关问题分析
2024-01-26 05:18:21
linux实现定时备份mysql数据库的简单方法
2024-01-16 07:21:57
互联网产品设计师职业生涯
2009-04-20 20:41:00
详解如何使用vue-cli脚手架搭建Vue.js项目
2023-07-02 17:05:19
![](https://img.aspxhome.com/file/2023/1/139921_0s.png)
基于Oracle的高性能动态SQL程序开发
2010-07-20 13:01:00
Flask-Sqlalchemy的基本使用详解
2023-06-16 19:40:02
![](https://img.aspxhome.com/file/2023/4/76044_0s.jpg)
python 代码实现k-means聚类分析的思路(不使用现成聚类库)
2021-05-28 06:30:24
![](https://img.aspxhome.com/file/2023/3/98803_0s.png)
OpenCV使用KNN完成OCR手写体识别
2022-02-17 12:16:21
![](https://img.aspxhome.com/file/2023/9/115079_0s.png)
SQL语句练习实例之七 剔除不需要的记录行
2011-11-03 16:50:51
python数字图像处理实现直方图与均衡化
2021-04-01 14:44:59
![](https://img.aspxhome.com/file/2023/7/120937_0s.png)