在 CI 构建期间,我使用 PostGres 的 JOOQ maven 插件生成 stub 。 (我无法在 CI 运行旁边的容器中轻松旋转专用的 PostGres/嵌入式 Postgres)。 H2 在自动构建/测试运行期间更方便。
我所做的是,使用 PostGres 模式运行 H2 以使用 maven 插件生成类
<plugin>
<groupId>org.jooq</groupId>
<artifactId>jooq-codegen-maven</artifactId>
<version>3.11.3</version>
<dependencies>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<version>${h2.version}</version>
</dependency>
<dependency>
<groupId>org.postgresql</groupId>
<artifactId>postgresql</artifactId>
<version>42.2.4.jre7</version>
</dependency>
</dependencies>
<executions>
<execution>
<id>jooq-codegen</id>
<phase>generate-sources</phase>
<goals>
<goal>generate</goal>
</goals>
<configuration>
<jdbc>
<driver>org.h2.Driver</driver>
<url>jdbc:h2:./jooq;AUTO_SERVER=TRUE;MODE=PostgreSQL</url>
<user>sa</user>
<password></password>
</jdbc>
<generator>
<name>org.jooq.codegen.JavaGenerator</name>
<database>
<name>org.jooq.meta.h2.H2Database</name>
<includes>.*</includes>
<!-- we don't want the flyway stuff in the code -->
<excludes>Flyway_.*</excludes>
<inputSchema>PUBLIC</inputSchema>
</database>
<!-- Put the Custom Generator Code here -->
<generate>
<deprecated>false</deprecated>
<instanceFields>true</instanceFields>
<pojos>true</pojos>
</generate>
<target>
<packageName>com.something.jooq</packageName>
<directory>target/generated-sources/jooq-h2</directory>
</target>
</generator>
</configuration>
</execution>
</executions>
</plugin>
这很完美,除非我从 ENUM 开始。当基础是 H2 db 时,JOOQ 为 ENUM 的每个用法(!)生成一个 EnumType,而使用 PostGres 时只有一个 EnumType(这就是我期望它工作的方式)。
例如:
我在数据库中创建一个枚举类型
create type state as enum ('start', 'stop')
我在两个表中使用这种类型,JOOQ 使用 PostGre Modus 中的 H2 生成两个枚举。
因此,如果我在 PostGres 和 H2 之间切换,也会生成代码更改和实现。
尽管数据库不同,是否可以强制 JOOQ 生成相同的类?
最佳答案
H2 的 enum
类型的当前(仍然相当实验性)实现更多地对应于 MySQL(每个表类型)而不是 PostgreSQL(每个模式类型),即使 CREATE H2 中模拟了 TYPE
语句支持。详情请参阅本期:
https://github.com/h2database/h2database/issues/1261
因此,就目前情况而言,您无法在 H2 上模拟 PostgreSQL 的枚举类型。
使用 H2 的旁注
话虽如此,一旦您使用任何供应商特定的功能(您应该这样做,因为 PostgreSQL 非常棒并且拥有大量这些功能),您使用 H2 的方法(因为它似乎更容易)是有很大缺陷的。您将一次又一次地遇到像这样的特定限制,并且与为该任务正确设置 PostgreSQL 实例相比,您将花费更多时间来解决这些限制。我强烈建议您不要使用 H2。关于postgresql - 如何使用 JOOQ 使用 H2 - ENUM 类型为 PostGres 生成 stub ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51621385/