5

编辑原来有一个 H2 数据库位于 mysql 数据库之上。我写的查询改为命中 H2。我会继续研究看看这是否可行

我有两个要同时更新的表,其中一个表的值由存储在另一个表中的值确定。我的更新查询如下所示:

UPDATE table1 AS A INNER JOIN table2 AS B
ON A.COL1 = B.COL1
AND A.COL2 = B.COL2
SET A.COL3 = 'SOME VAL',
B.COL4 = B.COL4 - A.COL4,
B.COL5 = B.COL5 - A.COL4
WHERE A.ID IN (23,5,21)

我在执行 INNER JOIN 的地方收到一个语法错误,上面写着“预期的“SET”。

我相信我应该能够使用 LEFT JOIN和http://dev.mysql.com/doc/refman/5.0/en/update.html在 MySQL 中为每个 UPDATE 多个表执行此连接更新。有人知道我的语法错误是什么吗?

为后代更新
首先,感谢 Thomas Mueller 的帮助。

我最终使用了以下语法,因为我发现它有些令人困惑,所以我将它留在这里以供将来的观众使用。

UPDATE TABLE1 SET(COL1, COL2) = 
( SELECT T1.COL1 - T2.AMNT, T1.COL2 + T2.AMNT
  FROM TABLE1 T1 RIGHT JOIN TABLE2 T2
  ON T1.COL3 = T2.COL3
  AND T1.COL4 = T2.COL4
  WHERE T2.ID = 23)
WHERE EXISTS 
(  SELECT * 
   FROM TABLE2
   WHERE TABLE1.COL3 = TABLE2.COL3
   AND TABLE1.COL4 = TABLE2.COL4
   AND TABLE2.ID = 23)

注意:我必须在第一个选择中使用连接,因为我无法让我们在下面讨论的语法起作用。

由于使用此方法,如果我得到一个 table2 id 列表(在我的原始示例中为 23、5、21),我必须执行多个更新语句。如果有人知道更好的方法来做到这一点,请告诉我。

4

1 回答 1

3

H2 不支持在一个 SQL 语句中同时更新两个表。您将需要使用两个语句。有关支持的语法,请参阅UPDATE语句 railroad diagram

于 2013-05-01T16:21:44.420 回答