错误 CREATE DATABASE cannot 运行 inside a transaction block
Error CREATE DATABASE cannot run inside a transaction block
我正在尝试使用 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 尚不支持此语句 - 如果我没记错的话,正是出于这个原因。也许有不同的方式来模拟该语句,但尚未实现。
我正在尝试使用 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 尚不支持此语句 - 如果我没记错的话,正是出于这个原因。也许有不同的方式来模拟该语句,但尚未实现。