我试图在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。这会导致问题吗?
答案 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。