问题说明
MybatisPlus3.5.5与pagehelper starter2.1.0同时引用了jsqlparser4.6和4.7在idea中使用并不会报错,打包之后用jar运行便会出现错误
- 如果以jsqlparser4.7版本为准,启动项目都起不起来,原因是jsqlparser4.7版本中把版本4.6的一个类被干掉了
- 如果以jsqlparser4.6版本为准,启动可以成功,但是查询会有问题
解决方案
https://github.com/pagehelper/Mybatis-PageHelper/issues/802
https://github.com/pagehelper/Mybatis-PageHelper/releases/tag/v6.1.0
首先确认两个依赖的版本号为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兼容包,并重新注册即可。