gpt4 book ai didi

database - 在一个查询中更新和插入(不是更新插入)

转载 作者:行者123 更新时间:2023-11-29 13:46:53 24 4
gpt4 key购买 nike

我正在使用 PostgreSQL。

我有表 A、B、C 和 D。

表 A 有表 B 的外键(因此一对多)。

表 C 和 D 具有表 A 的外键(一对多)。所以它看起来像:

B :-> A :-> C & D

现在我想添加一个中间表E来建立关系:

E :-> C & D(一对多)

B -> E(与 fk 一对一)

B :-> A(一对多)

我需要它来引入表 F,它也将有一个到表 E 的外键。

表 E 只有一个标识列“id”。

现在我必须编写一个迁移并且不知道如何向 E 添加行并同时更新 B

在伪 SQL 中它必须是这样的:

更新BSET A_id = id插入 A (id)

最佳答案

您可以为此使用 WITH 语句:

WITH inserted_rows AS (
INSERT INTO A(...) VALUES (...) RETURNING *
) UPDATE B SET A_id = a.id FROM inserted_rows a WHERE ...;

WHERE 子句应该过滤B 的匹配行。不幸的是,你的问题非常广泛,所以我不能给你一个更详细的例子。

关于database - 在一个查询中更新和插入(不是更新插入),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46964934/

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