postgresql - 错误 CREATE DATABASE 无法在事务 block 内运行

标签 postgresql jooq micronaut

我正在尝试使用 jOOQ 从在 Micronaut 框架中运行的 Java 应用程序创建数据库。

代码

contextSupplier.get().createDatabaseIfNotExists(this.databaseName).execute();

使用 PostgreSQL 数据源失败:

org.jooq.exception.DataAccessException: SQL [do $$ begin create database "mydb"; exception when sqlstate '42P07' then null; end $$]; ERROR: CREATE DATABASE cannot run inside a transaction block

是否有一种简单的方法可以在 jOOQ 中仅针对此语句关闭事务?

最佳答案

从 jOOQ 3.14 开始,DSLContext.createDatabaseIfNotExists()这些方言支持该方法(请参阅其 @Support 注释):

@Support({AURORA_POSTGRES,COCKROACHDB,MARIADB,MEMSQL,MYSQL,SQLDATAWAREHOUSE,SQLSERVER})

因此,jOOQ for PostgreSQL 尚不支持此语句 - 如果我没记错的话,正是出于这个原因。也许有不同的方式来模拟该语句,但尚未实现。

关于postgresql - 错误 CREATE DATABASE 无法在事务 block 内运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66430905/

相关文章:

database - 理解 postgres 缓存

java - Jooq模型生成中的字符集问题

java - 如何从配置层次结构的根读取 Micronaut 数组属性?

java - 如何禁用 micronaut 的静态内容缓存?

micronaut - 定义一个在 Hibernate SessionFactory 之前启动的 Micronaut bean

windows - 是否可以为 Windows 7 和/或 8 创建不区分大小写的自定义区域设置?

java - 表存在时出现SQLException

node.js - NodeJs - Sequelize - 无法识别的属性数据类型

hibernate - 如何将 ResultSet 对象转换为 Hibernate Entity Bean

sql - Postgres 中的记录交集