ChatGPT解决这个技术问题 Extra ChatGPT

如何在 UPDATE 查询中执行三个表 JOIN?

我问了一个问题,得到了这个有帮助的答复。

   UPDATE TABLE_A a JOIN TABLE_B b
   ON a.join_col = b.join_col AND a.column_a = b.column_b
   SET a.column_c = a.column_c + 1

现在,如果有三个表涉及这样的事情,我希望这样做。

    UPDATE tableC c JOIN tableB b JOIN tableA a

我的问题基本上是......是否可以在 UPDATE 语句上进行三个表连接?它的正确语法是什么?

我是否执行以下操作?

 JOIN tableB, tableA
 JOIN tableB JOIN tableA
当然有可能。试试看。语法就像您拥有的一样 - 您只需添加下一个 JOIN 及其 ON 条件,就像在 SELECT 查询中一样。
UPDATE t1 JOIN t2 ON t1.id = t2.t1_id JOIN t3 ON t3.id = t2.t3_id SET t1.col = 'newval'
提到的问题在这里:stackoverflow.com/questions/15206746/…

P
Peter Mortensen

答案是肯定的,你可以。

试试这样:

UPDATE TABLE_A a
    JOIN TABLE_B b ON a.join_col = b.join_col AND a.column_a = b.column_b
    JOIN TABLE_C c ON [condition]
SET a.column_c = a.column_c + 1

对于一般更新加入:

UPDATE TABLEA a
JOIN TABLEB b ON a.join_colA = b.join_colB
SET a.columnToUpdate = [something]

然而奇怪的是,我的 HeidiSQL 软件报告的受影响行为零,尽管数据显示更新已完成。
@Pianoman对我来说它也发生了,它与ON UPDATE CURRENT_TIMESTAMP有关,我只是手动添加了更新并修复了它,只是说它是否发生在其他人身上
如果您需要视觉辅助来正确连接:browse-tutorials.com/tutorial/mysql-joins-visual-representation
我认为以下是一个更好的总体计划:UPDATE table A JOIN table B ON {join data} JOIN table C ON {join data} JOIN {more join tables} SET A.column = {expression}(如果这个该死的编辑不让我在没有完整发布的情况下输入换行符,请原谅我)
@green WHERE 在 SET 之后最后出现。 echo_Me 请在您的帖子中添加 WHERE,因为后面的评论不会显示。
P
Peter Mortensen

achieving the same result 的另一种方法是根本不使用 JOIN 关键字。

UPDATE TABLE_A, TABLE_B
SET TABLE_A.column_c = TABLE_B.column_c + 1
WHERE TABLE_A.join_col = TABLE_B.join_col

我在 5.5.62 上试过这个,mysql 不喜欢这种语法。根据手册[dev.mysql.com/doc/refman/5.6/en/update.html],查询应该是:UPDATE TABLE_A, TABLE_B SET TABLE_A.column_c = TABLE_A.column_c +1 WHERE TABLE_A.join_col = TABLE_B.join_col
这会以与执行 SELECT * FROM TABLE_A, TABLE_B ... 相同的方式执行隐式 JOIN
那么这是否意味着在 5.5 中只接受隐式连接形式进行更新?
@userfuser 不,它没有,手册说明了语法:UPDATE [LOW_PRIORITY] [IGNORE] table_references SET col_name1={expr1|DEFAULT} [, col_name2={expr2|DEFAULT}] ... [WHERE where_condition] 后来,手册说明:“table_references 子句列出了连接中涉及的表。它的语法在 Section 13.2.9.2, JOIN Syntax 中描述。”
不完全相同的结果——您可以使用连接语法进行左连接。
P
Peter Mortensen

下面是包含 JOINWHEREupdate 查询。同样,我们可以使用多个 join/where 子句:

UPDATE opportunities_cstm oc JOIN opportunities o ON oc.id_c = o.id
 SET oc.forecast_stage_c = 'APX'
 WHERE o.deleted = 0
   AND o.sales_stage IN('ABC','PQR','XYZ')

欢迎来到堆栈溢出!感谢您提供此代码片段,它可能会提供一些即时帮助。正确解释would greatly improve其教育价值,通过展示为什么这是一个很好的问题解决方案,并将使其对未来有类似但不相同的问题的读者更有用。请edit您的回答以添加解释,并说明适用的限制和假设。
P
Peter Mortensen

另一种总体计划:

UPDATE table A
JOIN table B ON {join fields}
JOIN table C ON {join fields}
JOIN {as many tables as you need}
SET A.column = {expression}

例子:

UPDATE person P
JOIN address A ON P.home_address_id = A.id
JOIN city C ON A.city_id = C.id
SET P.home_zip = C.zipcode;

P
Peter Mortensen

是的,您可以为更新语句执行三表连接。这是一个例子:

UPDATE customer_table c

  JOIN
      employee_table e
      ON c.city_id = e.city_id
  JOIN
      anyother_ table a
      ON a.someID = e.someID

SET c.active = "Yes"

WHERE c.city = "New york";

P
Peter Mortensen

对于 PostgreSQL 示例:

UPDATE TableA AS a
SET param_from_table_a=FALSE -- param FROM TableA
FROM TableB AS b
WHERE b.id=a.param_id AND a.amount <> 0;

a
arman amirkamali

没有一个答案对我不起作用我在 mysql 手册上找到了这个

UPDATE T1,T2 INNER JOIN T2 ON T1.C1 = T2.C1 SET T1.C2 = T2.C2,       T2.C3 = expr WHERE condition