MybatisPlus3.5.5与pagehelper starter2.1.0冲突的问题解决
问题说明
MybatisPlus3.5.5与pagehelper starter2.1.0同时引用了jsqlparser4.6和4.7在idea中使用并不会报错,打包之后用jar运行便会出现错误
- 如果以jsqlparser4.7版本为准,启动项目都起不起来,原因是jsqlparser4.7版本中把版本4.6的一个类被干掉了
- 如果以jsqlparser4.6版本为准,启动可以成功,但是查询会有问题
解决方案
首先确认两个依赖的版本号为3.5.5 和 2.1.0
<dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper-spring-boot-starter</artifactId> <version>2.1.0</version> <exclusions> <exclusion> <groupid>com.github.jsqlparser</groupid> <artifactId>jsqlparser</artifactId> </exclusion> </exclusions> </dependency> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.5.5</version> <exclusions> <exclusion> <groupid>com.github.jsqlparser</groupid> <artifactId>jsqlparser</artifactId> </exclusion> </exclusions> </dependency> <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>sqlparser4.5</artifactId> <version>6.1.0</version> </dependency>
建立两个类
import com.github.pagehelper.dialect.helper.MySqlDialect; import com.github.pagehelper.parser.CountJSqlParser45; import com.github.pagehelper.parser.CountSqlParser; import com.github.pagehelper.parser.OrderByJSqlParser45; import com.github.pagehelper.parser.OrderBySqlParser; import com.github.pagehelper.util.ClassUtil; import java.util.Properties; /** * 解决Mybatis Plus与PageHelper之间的冲突 * 覆盖父类 {@link com.github.pagehelper.dialect.AbstractDialect} 中的setProperties方法, * 将CountJSqlParser45、OrderByJSqlParser45提供的两个类来替换掉Default类 * * @Author zsp * @Date 2024/7/9 **/ public class LocalMySqlDialect extends MySqlDialect { @Override public void setProperties(Properties properties) { this.countSqlParser = ClassUtil.newInstance(properties.getProperty("countSqlParser"), CountSqlParser.class, properties, CountJSqlParser45::new); this.orderBySqlParser = ClassUtil.newInstance(properties.getProperty("orderBySqlParser"), OrderBySqlParser.class, properties, OrderByJSqlParser45::new); } }
import com.github.pagehelper.page.PageAutoDialect; import org.springframework.boot.ApplicationArguments; import org.springframework.boot.ApplicationRunner; import org.springframework.stereotype.Component; /** * 在spring boot启动完成后将LocalMySqlDialect注册进pagehelper * * @Author zsp * @Date 2024/7/9 **/ @Component public class DialectInit implements ApplicationRunner { @Override public void run(ApplicationArguments args) throws Exception { PageAutoDialect.registerDialectAlias("mysql", LocalMySqlDialect.class); } }
原理
PageAutoDialect这个类是用来管理注册方言的,它在MySql的方言中默认使用了com.github.pagehelper.dialect.helper.MySqlDialect
类,而MySqlDialect
类继承自com.github.pagehelper.dialect.AbstractDialect
类,而AbstractDialect
默认实现了setProperties
方法,我们覆盖掉这个方法,使用官方提供的4.5兼容包,并重新注册即可。
到此这篇关于MybatisPlus3.5.5与pagehelper starter2.1.0冲突的问题解决的文章就介绍到这了,更多相关MybatisPlus3.5.5与pagehelper starter2.1.0冲突内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
解决java Graphics drawImage 无法显示图片的问题
这篇文章主要介绍了解决java Graphics drawImage 无法显示图片的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-11-11Nacos启动出现failed to req API:/nacos/v1/ns/insta
这篇文章主要介绍了Nacos启动出现failed to req API:/nacos/v1/ns/instance after all servers问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2024-08-08JavaWeb入门:HttpResponse和HttpRequest详解
这篇文章主要介绍了Django的HttpRequest和HttpResponse对象,分享了相关代码示例,小编觉得还是挺不错的,具有一定借鉴价值,需要的朋友可以参考下2021-07-07
最新评论