zoukankan      html  css  js  c++  java
  • 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的依赖项移到最下面

      

      再次运行,依然执行成功,问题解决!

  • 相关阅读:
    vue 路由跳转返回上一级
    js中Let和Var的区别
    JS实现电话号码校验座机:区号号码、或11位手机号
    VUE 监听 对象属性值变化的三种方式
    vue中computed的用法
    elementUI中input输入框,强制输入数字,并限制输入长度
    C++中__int64用法
    WIN10计算器设计可能出现的坑
    跳转acticity
    asp.net邮件发送
  • 原文地址:https://www.cnblogs.com/handsomeye/p/6279382.html
Copyright © 2011-2022 走看看