Mybatis中同時使用shardbatis和pagehelper插件沖突問題


  在一次使用mybatis的插件,分表shardbatis+分頁pagehelper共同使用的時候,會拋出以下異常:

java.lang.NoSuchMethodError: net.sf.jsqlparser.util.deparser.StatementDeParser.<init>(Ljava/lang/StringBuffer;)V
    at com.google.code.shardbatis.converter.AbstractSqlConverter.doDeParse(AbstractSqlConverter.java:28)
    at com.google.code.shardbatis.converter.AbstractSqlConverter.convert(AbstractSqlConverter.java:19)
    at com.google.code.shardbatis.converter.SqlConverterFactory.convert(SqlConverterFactory.java:78)
    at com.google.code.shardbatis.plugin.ShardPlugin.intercept(ShardPlugin.java:68)
    at org.apache.ibatis.plugin.Plugin.invoke(Plugin.java:60)

  但是,這個錯只有在junit測試的時候才會報出,而tomcat啟動,頁面調用,則不會報錯!!!!

  查看StatementDeParser類中,存在"上面提示不存在的方法",那到底是什么原因?

  突然一想,剛剛在搜索StatementDeParser類的時候,發現存在0.8.0和0.9.5兩個版本的包,猜想也許是這個問題導致的。

  查看pom.xml配置如下:

     <!-- 分頁插件 -->
        <dependency>
            <groupId>com.github.pagehelper</groupId>
            <artifactId>pagehelper</artifactId>
            <version>4.1.6</version>
        </dependency>
        <!-- 分表插件 -->
        <dependency>
            <groupId>org.shardbatis</groupId>
            <artifactId>shardbatis</artifactId>
            <version>2.0.0B</version>
        </dependency>
        <dependency>
            <groupId>net.sf.jsqlparser</groupId>
            <artifactId>jsqlparser</artifactId>
            <version>0.8.0</version>
        </dependency>

  這時候,可以看到maven依賴的包里,存在兩個jsqlparser.jar

  

  jsqlparser-0.9.5.jar從何而來???原來pagehelper中存在pom.xml,會自動引入0.9.5版本的包

  

  於是,我將pom.xml中pagehelper的依賴項注釋掉,這時候,只有下面兩個包

  

  再運行測試用例,執行成功!!!

  可是,我必須要同時使用兩個插件,怎么辦???只好將pagehelper的依賴項移到最下面

  

  再次運行,依然執行成功,問題解決!

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM