使用JOOQ的java.lang.NoSuchMethodError

时间:2014-04-06 10:43:01

标签: java maven glassfish jooq

我试图在glassfish中使用JOOQ。我使用这样的代码生成器:

java -cp jOOQ-lib/jooq-3.3.1.jar:jOOQ-lib/jooq-meta-3.3.1.jar:jOOQ-lib/jooq-codegen-3.3.1.jar:mysql-connector-java-5.1.29-bin.jar:. org.jooq.util.GenerationTool /db.xml

然后将生成的文件夹导入我的项目。(我没有使用jooq maven插件)。当我在glassfish中部署web应用程序时,我在server.log中看到了这一点

[#|2014-04-06T14:53:37.720+0430|SEVERE|glassfish3.1.2|com.sun.xml.ws.server.sei.TieHandler|_ThreadID=670;_ThreadName=Thread-2;|org.jooq.impl.TableImpl.<init>(Ljava/lang/String;Lorg/jooq/Schema;Lorg/jooq/Table;[Lorg/jooq/Field;Ljava/lang/String;)V
    java.lang.NoSuchMethodError: org.jooq.impl.TableImpl.<init>(Ljava/lang/String;Lorg/jooq/Schema;Lorg/jooq/Table;[Lorg/jooq/Field;Ljava/lang/String;)V

我没有更改任何maven配置只是netbeans默认配置。 maven神器:

<dependency>
    <groupId>org.jooq</groupId>
    <artifactId>jooq</artifactId>
    <version>3.3.1</version>
</dependency>

我的db.xml:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<configuration>
  <!-- Configure the database connection here -->
  <jdbc>
    <driver>com.mysql.jdbc.Driver</driver>
    <url>jdbc:mysql://127.0.0.1/bulkdb?useUnicode=true</url>
    <user>user</user>
    <password>pass</password>
  </jdbc>
    <generator>
        <database>
            <name>org.jooq.util.mysql.MySQLDatabase</name>
            <inputSchema>bulkdb</inputSchema>
            <includes>.*</includes>
            <excludes></excludes>
        </database>
        <target>
            <packageName>bulkdb</packageName>
            <directory>/home/user/jooq</directory>
        </target>
    </generator>

</configuration>

出了什么问题?有人可以帮忙吗?

[UPDATE]

实际上在app服务器类路径中有两个版本的JOOQ:一个在域(lib1 / lib /)的lib目录中,版本为3.1,第二个是在war文件中捆绑的3.3.1。这会导致问题吗?

1 个答案:

答案 0 :(得分:2)

  

实际上在app服务器类路径中有两个版本的JOOQ:一个在域(lib1 / lib /)的lib目录中,版本为3.1,第二个是在war文件中捆绑的3.3.1。这会导致问题吗?

是的,当然: - )

如果你想同时使用这两个版本(你真的吗?),那么你可能需要求助于类似OSGi的东西才能在不同的类加载器中加载相同的类名。

在您的情况下,您的应用程序服务器首先加载jOOQ 3.1,因此无法再完全加载jOOQ 3.3。使用jOOQ 3.3生成的代码对TableImpl中的新内部方法进行操作,这些方法已在jOOQ 3.2或3.3中添加,但由于您正在加载jOOQ 3.1,因此这些方法不存在。请注意,任何外部依赖项都可能发生这种情况。

这里的解决方案是从应用程序服务器中删除jOOQ 3.1。