欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MybatisPlus3.5.5與pagehelper?starter2.1.0沖突的問題解決

 更新時(shí)間:2024年10月11日 09:51:11   作者:酒醉的胡鐵  
在使用MybatisPlus?3.5.5與PageHelper?Starter?2.1.0時(shí),由于引用了不同版本的jsqlparser庫(4.6與4.7),會(huì)導(dǎo)致運(yùn)行時(shí)錯(cuò)誤,解決方案涉及確認(rèn)依賴版本,本文就來介紹一下,感興趣的同學(xué)可以下載學(xué)習(xí)

問題說明

MybatisPlus3.5.5與pagehelper starter2.1.0同時(shí)引用了jsqlparser4.6和4.7在idea中使用并不會(huì)報(bào)錯(cuò),打包之后用jar運(yùn)行便會(huì)出現(xiàn)錯(cuò)誤

在這里插入圖片描述

  • 如果以jsqlparser4.7版本為準(zhǔn),啟動(dòng)項(xiàng)目都起不起來,原因是jsqlparser4.7版本中把版本4.6的一個(gè)類被干掉了
  • 如果以jsqlparser4.6版本為準(zhǔn),啟動(dòng)可以成功,但是查詢會(huì)有問題

解決方案

首先確認(rèn)兩個(gè)依賴的版本號(hào)為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>

建立兩個(gè)類

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提供的兩個(gè)類來替換掉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啟動(dòng)完成后將LocalMySqlDialect注冊(cè)進(jìn)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這個(gè)類是用來管理注冊(cè)方言的,它在MySql的方言中默認(rèn)使用了com.github.pagehelper.dialect.helper.MySqlDialect類,而MySqlDialect類繼承自com.github.pagehelper.dialect.AbstractDialect類,而AbstractDialect默認(rèn)實(shí)現(xiàn)了setProperties方法,我們覆蓋掉這個(gè)方法,使用官方提供的4.5兼容包,并重新注冊(cè)即可。

到此這篇關(guān)于MybatisPlus3.5.5與pagehelper starter2.1.0沖突的問題解決的文章就介紹到這了,更多相關(guān)MybatisPlus3.5.5與pagehelper starter2.1.0沖突內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • java?map的key值轉(zhuǎn)駝峰命名的方法

    java?map的key值轉(zhuǎn)駝峰命名的方法

    這篇文章主要介紹了java?map的key值轉(zhuǎn)駝峰,通過實(shí)例代碼介紹了Map把“_”形式的key轉(zhuǎn)化為駝峰形式,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-12-12
  • Java冒泡排序詳解(附有詳細(xì)代碼)

    Java冒泡排序詳解(附有詳細(xì)代碼)

    冒泡排序是一種簡(jiǎn)單的排序算法,通過相鄰元素的比較和交換來實(shí)現(xiàn),它雖然在效率上不如其他排序算法,但在某些特定場(chǎng)景下仍然有其應(yīng)用價(jià)值,這篇文章主要介紹了Java冒泡排序的相關(guān)資料,文中給出了詳細(xì)的代碼示例,需要的朋友可以參考下
    2025-04-04
  • Java如何利用策略模式替代if/else語句

    Java如何利用策略模式替代if/else語句

    這篇文章主要介紹了Java如何利用策略模式替代if/else語句,幫助大家優(yōu)化自己的代碼,提高程序運(yùn)行效率,感興趣的朋友可以了解下
    2020-09-09
  • Java Clone(類的復(fù)制)實(shí)例代碼

    Java Clone(類的復(fù)制)實(shí)例代碼

    Java Clone(類的復(fù)制)實(shí)例代碼,需要的朋友可以參考一下
    2013-03-03
  • netflix.discovery.shared.transport.TransportException:Cannot execute request on any known server

    netflix.discovery.shared.transport.TransportException:Cannot

    這篇文章主要介紹了netflix.discovery.shared.transport.TransportException:Cannot execute request on any known server報(bào)錯(cuò)問題及解決方法,感興趣的朋友一起看看吧
    2023-09-09
  • java編程實(shí)現(xiàn)并查集的路徑壓縮代碼詳解

    java編程實(shí)現(xiàn)并查集的路徑壓縮代碼詳解

    這篇文章主要介紹了java編程實(shí)現(xiàn)并查集的路徑壓縮代碼詳解,具有一定借鑒價(jià)值,需要的朋友可以參考。
    2017-11-11
  • 如何解決zookeeper集群重啟Error contacting service.It is probably not running問題

    如何解決zookeeper集群重啟Error contacting service.It 

    本文詳細(xì)介紹了Zookeeper集群?jiǎn)?dòng)異常的排查步驟,包括網(wǎng)絡(luò)問題、防火墻配置、Java環(huán)境、端口占用、網(wǎng)卡問題、網(wǎng)絡(luò)問題以及節(jié)點(diǎn)配置信息的檢查,通過逐一排查和解決這些問題,可以有效地啟動(dòng)Zookeeper集群
    2024-12-12
  • java注解實(shí)現(xiàn)websocket服務(wù)的兩種方式

    java注解實(shí)現(xiàn)websocket服務(wù)的兩種方式

    Java WebSocket是一種基于TCP協(xié)議的雙向全雙工消息傳輸技術(shù),它允許服務(wù)器和客戶端之間實(shí)時(shí)通信,具有低延遲和高效率的特點(diǎn),下面這篇文章主要給大家介紹了關(guān)于java注解實(shí)現(xiàn)websocket服務(wù)的兩種方式,需要的朋友可以參考下
    2024-08-08
  • 一篇文章帶你了解SpringMVC數(shù)據(jù)綁定

    一篇文章帶你了解SpringMVC數(shù)據(jù)綁定

    這篇文章主要給大家介紹了關(guān)于如何通過一篇文章弄懂Spring MVC的參數(shù)綁定,文中通過示例代碼以及圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-08-08
  • IDEA POM文件配置profile實(shí)現(xiàn)不同環(huán)境切換的方法步驟

    IDEA POM文件配置profile實(shí)現(xiàn)不同環(huán)境切換的方法步驟

    這篇文章主要介紹了IDEA POM文件配置profile實(shí)現(xiàn)不同環(huán)境切換的方法步驟
    2024-03-03

最新評(píng)論