gpt4 book ai didi

postgresql - 如何在 PostgreSql 上与 Jooq 级联截断?

转载 作者:行者123 更新时间:2023-11-29 13:38:34 26 4
gpt4 key购买 nike

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

我正在开发一个使用 Kotlin、Spring 和 Jooq 的应用程序,这就是为什么我使用 truncateCascade 来成像一个 Truncator 类,我可以将它自动连接到我的 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 或数据库经验来将其拼凑起来。

最佳答案

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

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

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

关于postgresql - 如何在 PostgreSql 上与 Jooq 级联截断?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58859941/

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