程序员开发实例大全宝库

网站首页 > 编程文章 正文

使用mybatis分页插件PageHelper5.0.0遇到的问题总结

zazugpt 2024-08-30 04:35:42 编程文章 17 ℃ 0 评论

PageHelper5.0.0和PageHelper4.0.0是有区别的大家注意

开始我的mybatis全局配置文件是这样写的:

<plugins>
<plugin interceptor="com.github.pagehelper.PageHelper">
<!-- 设置数据库类型 Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL六种数据库-->
<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="true"/>-->
 <!-- 3.5.0版本可用 - 为了支持startPage(Object params)方法 -->
 <!-- 增加了一个`params`参数来配置参数映射,用于从Map或ServletRequest中取值 -->
 <!-- 可以配置pageNum,pageSize,count,pageSizeZero,reasonable,orderBy,不配置映射的用默认值 -->
 <!-- 不理解该含义的前提下,不要随便复制该配置 -->
 <!--<property name="params" value="pageNum=start;pageSize=limit;"/>-->
 <!-- 支持通过Mapper接口参数来传递分页参数 -->
 <!--<property name="supportMethodsArguments" value="true"/>-->
 <!-- always总是返回PageInfo类型,check检查返回类型是否为PageInfo,none返回Page -->
 <!--<property name="returnPageInfo" value="check"/>-->
</plugin>
</plugins>

启动tomcat报错:如图

后面还有一行描述:Cause:java.lang.ClassCastException:com.github.pagehelper.PageHelper cannot be cast to org.apache.ibatis.plugin.Interceptor

意思就是说这个分页插件的Interceptor没有被实现

来看一下我的,PageHelper版本,以及com.github.pagehelper.PageHelper类

pageHelper是如何在mybatis中工作呢,是通过mybatis的pulgin实现了Interceptor接口,从而获得要执行的sql语句实现分页技术,而我们的PageHelper5.0.0版本中的这个类,并没有出现implements Interceptor,我们再来看下pagehelper这个包下的其他类,我们发现,有个类很像我们要的,我们进去一看,果然是它:

因此,我们设定分页插件的方言dialect的value,我们使用的是mysql数据库,因此value=mysql。修改我们的mybatis全局配置文件mybatis-config.xml如下:

我们再次,运行项目发现又报了一个跟PageHelper相关的错误:如下

我尼玛,要懵逼了,继续看错误,主要2个错误

Caused by: org.apache.ibatis.builder.BuilderException: Error parsing SQL Mapper Configuration. Cause: com.github.pagehelper.PageException: java.lang.ClassNotFoundException: mysql

Caused by: com.github.pagehelper.PageException: java.lang.ClassNotFoundException: mysql

然后Google的结果是:

PageHelper插件4.0.0以后的版本支持自动识别使用的数据库,可以不用配置 <property name="dialect" value="mysql"/>

OK.....正常启动项目

写下这个问题,大家扫一眼,心里有个底,以后用不至于没有头绪的去寻找问题!

好了,今天的技术内容就分享给大家,码农不容易,小编给大家分享写博客也不容易,请多多支持,喜欢请关注头条号,每天都有功能和bug分享给大家一起学习进步,我们的目标是 ----软件攻城狮

码农不容易,码文章更不容易啊,喜欢小编多多支持请点击关注哦,小编会更加努力每天给大家分享技术文章。

Tags:

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表