gpt4 book ai didi

mysql - jOOQ如何根据配置处理多个数据库引擎

转载 作者:行者123 更新时间:2023-12-04 09:44:58 25 4
gpt4 key购买 nike

我是一个经验丰富且快乐的 jOOQ 用户。

我现在正在做一个需要支持多个数据库引擎(至少 PostgreSQL、MySQL、Oracle)的项目。

我们想要一些足够低级别的东西来控制我们的查询。 JPA/Hibernate 对我们来说太高了。

我知道 jOOQ 使用元模型,并且该元模型是从数据库模式生成的。

有什么方法可以针对不同的数据库引擎重用相同的 jOOQ 查询定义(除了引擎特定的差异之外,还有相同的模式)?

如果我们需要重新编译 java 类,那很好。编译时配置对我们来说很好。

最佳答案

jOOQ 就是为此而设计的。你需要做这些事情:

  • 有一个 Configuration with a SQLDialect 准备好取决于您的 JDBC 连接。这是容易的部分。那个Configuration将为您的所有 jOOQ 查询自动生成供应商特定的 SQL。这可以在运行时完成。不需要任何编译时调整。
  • 确保您的表/列始终使用相同的大小写,or turn off quoting in jOOQ's identifiers对于不区分大小写的行为(取决于您的 MySQL 配置,这可能还不够, see the MySQL manual )。然后,您可以在所有其他方言上重新使用从任何数据库方言生成的代码。
  • 确保您只使用带有 @Support({ MYSQL, ORACLE, POSTGRES }) 注释的 jOOQ API。 .例如, DSL.toDate() 不能使用,因为它不支持 MySQL,但是 DSL.trunc() 可以使用,因为所有 3 个目标方言都存在。

  • 我们也越来越多地向 jOOQ 手册添加方言特定信息,例如为 the SHL() function :

    -- ASE, HSQLDB, SQLDATAWAREHOUSE, SQLSERVER, SYBASE
    (1 * CAST(power(2, 4) AS int))

    -- AURORA_MYSQL, AURORA_POSTGRES, COCKROACHDB, CUBRID, MARIADB, MEMSQL, MYSQL, POSTGRES, SQLITE, VERTICA
    (1 << 4)

    -- DB2, INFORMIX
    (1 * CAST(power(2, 4) AS integer))

    -- FIREBIRD
    bin_shl(1, 4)

    -- H2
    lshift(1, 4)

    -- ORACLE
    (1 * CAST(power(2, 4) AS number(10)))

    -- TERADATA
    shiftleft(1, 4)

    -- ACCESS, DERBY, HANA, INGRES, REDSHIFT
    /* UNSUPPORTED */

    为了确保您不会意外编写不适用于某些方言的查询,您可以:
  • 运行集成测试,例如使用 testcontainers在每个目标方言
  • 使用 jOOQ's Checker Framework or ErrorProne integration用于静态代码分析。 See also this blog post here .
  • 关于mysql - jOOQ如何根据配置处理多个数据库引擎,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62173589/

    25 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com