如何解决错误 CREATE DATABASE 不能在事务块内运行
我正在尝试使用 jOOQ 从在 Micronaut 框架中运行的 Java 应用程序创建数据库。
代码
contextSupplier.get().createDatabaseIfNotExists(this.databaseName).execute();
使用 PostgreSQL 数据源失败:
org.jooq.exception.DataAccessException: SQL [do $$ begin create database "mydb"; sqlstate '42P07' 然后为空时的异常;结束 $$];错误:CREATE DATABASE 不能在事务块内运行
是否有一种简单的方法可以在 jOOQ 中仅针对此语句关闭事务?
解决方法
从 jOOQ 3.14 开始,这些方言支持 DSLContext.createDatabaseIfNotExists()
方法(请参阅其 @Support
注释):
@Support({AURORA_POSTGRES,COCKROACHDB,MARIADB,MEMSQL,MYSQL,SQLDATAWAREHOUSE,SQLSERVER})
因此,jOOQ for PostgreSQL 尚不支持此语句 - 如果我没记错的话,正是出于这个原因。也许有一种不同的方式来模拟该语句,但尚未实现。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。