postgresql - 如何使用 JOOQ 使用 H2 - ENUM 类型为 PostGres 生成 stub

标签 postgresql enums h2 jooq

在 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/

相关文章:

sql - 如何在 Postgres 9.1+ 函数中使用混合的 int 和数字参数

C# 通用枚举转换为特定枚举

c# - 将枚举作为字典集合中的键出现问题

h2 - 在 H2 中运行空间查询的语法是什么?

sql - 如何在H2数据库中将BLOB查询为CLOB

java - 如何在不更改数据库架构的情况下将 UrlType 从 Hibernate 3.6 迁移到 4.3?

函数上的 PostgreSQL-simple `execute` 失败并显示 "execute resulted in Col 1-column result"

ruby - 无法启动 sinatra 应用程序

python - Django - 具有 order_with_respect_to 属性的 bulk_create 对象

c++ - SWIG 和 C++ 枚举类