如何在 PostgreSql 上使用 Jooq 级联截断?

Posted

技术标签:

【中文标题】如何在 PostgreSql 上使用 Jooq 级联截断?【英文标题】:How to cascade truncate with Jooq on PostgreSql? 【发布时间】:2020-03-10 14:21:47 【问题描述】:

我正在编写集成测试,并希望在每次测试后清理(postgres)数据库。所以我假设对所有(实际上只是大部分)表进行级联截断操作是可行的方法。

我正在开发一个使用 Kotlin、Spring 和 Jooq 的应用程序,这就是为什么我使用 truncateCascadeTruncator 类进行映像,我可以将其自动连接到我的 SpringBootTest 类中。

import org.jooq.DSLContext
import org.jooq.Table

@Service
class Truncator(private val dsl: DSLContext) 
    fun truncateCascade(tables: List<Table<*>>) 
        dsl.truncate ...
    

//      single truncate work only for tables without foreign key constraints
//      so I can't simply iterate over all tables and call this method.
//    fun truncate(table: Table<*>) 
//        dsl.truncate(table).execute()
//    

基本上我正在寻找truncateCascade 的实现(假设这不是错误的方法)。

我在 Jooq 的 TruncateCascadeStep 上找到了文档,并在调查此问题时提到了 continueIdentity 或 restartIdentity,但我对 Jooq 或一般数据库的经验不足,无法将其拼凑起来。

【问题讨论】:

【参考方案1】:

您缺少的是在您的 truncate() 命令上调用 cascade()

fun truncate(table: Table<*>) 
    dsl.truncate(table).cascade().execute()

另一种选择是完全删除您的架构,然后从头开始重新创建它。这对于测试来说可能更健壮,并且对于中小型架构来说应该不会花费太多更多时间。

【讨论】:

一个级联看起来很奇怪。我不想同时删除一个表,而是多个表(因此vararg 现在更改为List,这意味着一个表数组)!否则外键约束会阻止我。还有一些表我不想删除,因为内容几乎是静态的,所以我们不要删除模式。 @StephanS:如果你运行truncate some_table cascade,它会自动截断任何引用some_table的表。如果您对每个单独的表使用 CASCADE,则不必在单个 TRUNCATE 命令中列出所有表 @StephanS:好吧,我假设您要编写您在评论中提到的那个循环。 :) 你只是忘了 (?) 添加 cascade() 关键字。 @a_horse_with_no_name 我认为(“自动截断引用 some_table 的任何表”)是拼图中缺失的部分!谢谢

以上是关于如何在 PostgreSql 上使用 Jooq 级联截断?的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 JOOQ 在 PostgreSQL 中插入带有 JSON 列的可更新记录?

如何在 jOOQ 中转换“to_json()”PostgreSQL 函数?

使用 jOOQ 在 PostgreSQL 中进行 UPSERT

如何使用 jOOQ 执行特定查询

jOOQ 无法映射 PostgreSQL 列以使 JPA 满意

JOOQ快速上手(基于springboot 和 postgresql)