gpt4 book ai didi

MySQL UPDATE 一个表,如果它们不相等,则使用另一个表中的值

转载 作者:行者123 更新时间:2023-11-29 01:04:21 25 4
gpt4 key购买 nike

我有两个表:

SELECT
d.id,
d.permission_lookup_id,
d.permission_object_id,
f.id,
f.permission_lookup_id,
f.permission_object_id
FROM
folders f
LEFT JOIN
documents d
ON f.id = d.folder_id
WHERE
d.permission_lookup_id != f.permission_lookup_id OR
d.permission_object_id != f.permission_object_id

理论上,如果一切顺利,这应该不会返回任何结果,但事实并非如此,我收到了数十万个结果(目前为 407,343)。我需要更新 documents 表,以便 permission_lookup_id 匹配 folderspermission_lookup_id 并且 permission_object_id ,基于 documents.parent_id 作为外键约束。

我尝试了以下查询但收效甚微:

UPDATE 
folders f
LEFT JOIN
documents d
ON f.id = d.folder_id
SET
d.permission_lookup_id = f.permission_lookup_id,
d.permission_object_id = f.permission_object_id
WHERE
d.permission_lookup_id != f.permission_lookup_id OR
d.permission_object_id != f.permission_object_id

运行后它告诉我有 70,986 行受影响,407343 行匹配,但我仍然有第一个选择查询的结果。

编辑:以下两个查询都返回 0 行:

SELECT * FROM folders WHERE permission_lookup_id IS NULL OR permission_object_id IS NULL;

SELECT * FROM documents WHERE permission_lookup_id IS NULL OR permission_object_id IS NULL;

同样适用于空白值。

编辑 2:在我最初的选择/更新查询中犯了一个业余错误。在 WHERE 子句中,我有:

WHERE
d.permission_lookup_id != f.permission_lookup_id OR
d.permission_object_id != f.permission_lookup_id

我应该去的地方

WHERE
d.permission_lookup_id != f.permission_lookup_id OR
d.permission_object_id != f.permission_object_id

这导致我收到误报,只会导致更新通过并更新每一列,无论是否需要。抱歉造成混淆。

最佳答案

这两个表中的 permission_lookup_id 是否有 NULL 值?如果是这样,您可能想尝试使用 NULL 安全运算符:

WHERE
(NOT d.permission_lookup_id <=> f.permission_lookup_id) OR
(NOT d.permission_object_id <=> f.permission_lookup_id)

更新

一次尝试一个字段只是为了查看和使用以下语法(这可能需要更长的时间才能运行):

UPDATE folders f
SET f.permission_lookup_id =COALESCE((SELECT d.permission_lookup_id FROM documents d
WHERE f.id = d.folder_id
AND d.permission_lookup_id != f.permission_lookup_id),
f.permission_lookup_id)

关于MySQL UPDATE 一个表,如果它们不相等,则使用另一个表中的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11582397/

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