mybatis分页插件pageHelper详解及简单实例

发布时间 - 2026-01-11 01:04:42    点击率:

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

这是如果接收参数为空字符串时它自身默认显示的页面和条数,这个可以自己规定

以上就是pageHelper的简单应用

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# mybatis分页插件pageHelper  # mybatis分页插件pageHelper使用方法  # Mybatis分页插件PageHelper的使用详解  # SpringBoot项目中分页插件PageHelper无效的问题及解决方法  # SpringMvc+Mybatis+Pagehelper分页详解  # PageHelper插件实现一对多查询时的分页问题  # Spring Boot+Mybatis+Druid+PageHelper实现多数据源并分页的方法  # Springboot整合pagehelper分页功能  # Mybatis分页插件PageHelper的配置和简单使用方法(推荐)  # SpringBoot集成MyBatis的分页插件PageHelper实例代码  # 使用mybatis插件PageHelper实现分页效果  # 使用PageHelper插件实现Service层分页  # 分页  # 配置文件  # 加载  # 这是  # 不去  # 也可  # 要注意  # 希望能  # 可在  # 就得  # 种方法  # 有两种  # 谢谢大家  # 会去  # 设置为  # 则会  # 必须先  # 不成功  # 就可以  # 为空 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何在阿里云购买域名并搭建网站?  Laravel如何实现多语言支持_Laravel本地化与国际化(i18n)配置教程  Python结构化数据采集_字段抽取解析【教程】  Laravel的.env文件有什么用_Laravel环境变量配置与管理详解  Laravel请求验证怎么写_Laravel Validator自定义表单验证规则教程  Laravel怎么判断请求类型_Laravel Request isMethod用法  Win11怎么关闭透明效果_Windows11辅助功能视觉效果设置  简历没回改:利用AI润色让你的文字更专业  JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)  Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程  Laravel怎么实现搜索功能_Laravel使用Eloquent实现模糊查询与多条件搜索【实例】  如何在橙子建站上传落地页?操作指南详解  Mybatis 中的insertOrUpdate操作  Laravel如何构建RESTful API_Laravel标准化API接口开发指南  Laravel怎么实现微信登录_Laravel Socialite第三方登录集成  如何在阿里云ECS服务器部署织梦CMS网站?  作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】  香港服务器建站指南:外贸独立站搭建与跨境电商配置流程  Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤  广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?  Laravel如何获取当前登录用户信息_Laravel Auth门面使用与Session用户读取【技巧】  ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】  如何快速搭建高效服务器建站系统?  Laravel如何处理CORS跨域问题_Laravel项目CORS配置与解决方案  微信h5制作网站有哪些,免费微信H5页面制作工具?  Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】  Laravel storage目录权限问题_Laravel文件写入权限设置  Laravel控制器是什么_Laravel MVC架构中Controller的作用与实践  如何在阿里云服务器自主搭建网站?  标题:Vue + Vuex + JWT 身份认证的正确实践与常见误区解析  郑州企业网站制作公司,郑州招聘网站有哪些?  jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】  如何彻底删除建站之星生成的Banner?  免费网站制作appp,免费制作app哪个平台好?  如何登录建站主机?访问步骤全解析  浅谈redis在项目中的应用  JavaScript实现Fly Bird小游戏  Laravel如何记录日志_Laravel Logging系统配置与自定义日志通道  Laravel如何创建自定义中间件?(Middleware代码示例)  nodejs redis 发布订阅机制封装实现方法及实例代码  北京企业网站设计制作公司,北京铁路集团官方网站?  高端云建站费用究竟需要多少预算?  如何快速选择适合个人网站的云服务器配置?  最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?  Laravel如何使用Passport实现OAuth2?(完整配置步骤)  Laravel distinct去重查询_Laravel Eloquent去重方法  Laravel怎么设置路由分组Prefix_Laravel多级路由嵌套与命名空间隔离【步骤】  Laravel如何处理文件上传_Laravel Storage门面实现文件存储与管理  Android中AutoCompleteTextView自动提示  详解MySQL数据库的安装与密码配置