更新涉及 MySQL 中多个联接的表
在处理涉及多个联接的复杂数据库查询时,更新特定表可能会带来挑战。虽然连接的顺序可能不会显着影响性能,但它会影响编写和读取查询的难易程度。
考虑以下示例,其中目标是更新 tableB 表:
UPDATE b FROM tableA a JOIN tableB b ON a.a_id = b.a_id JOIN tableC c ON b.b_id = c.b_id SET b.val = a.val+c.val WHERE a.val > 10 AND c.val > 10;
在上面的查询中,通过联接更新 tableB 涉及表 tableA 和 tableC。但是,tableB 并不是 FROM 子句中提到的第一个表。
与 Microsoft SQL Server 不同,MySQL 处理多表更新的方式不同。 UPDATE 语法不需要显式指定要更新的表。相反,SET 子句隐式更新包含被分配新值的列的表。
要使用 MySQL 语法实现所需的更新,请按如下方式修改查询:
UPDATE tableA a JOIN tableB b ON a.a_id = b.a_id JOIN tableC c ON b.b_id = c.b_id SET b.val = a.val + c.val WHERE a.val > 10 AND c.val > 10;
MySQL 的 UPDATE语法允许您通过使用 SET 子句中的列名来更新不是 FROM 子句中第一个表的表。
以上是如何使用多重连接高效更新 MySQL 中的表?的详细内容。更多信息请关注PHP中文网其他相关文章!