标签:oracle 更新两张表关联的数据
方法一(推荐):1 2 3 4 5 6 7 8 9 | UPDATE 表2 SET 表2.C = ( SELECT B FROM 表1 WHERE 表1.A = 表2.A) WHERE EXISTS ( SELECT 1 FROM 表1 WHERE 表1.A = 表2.A); |
尤其注意最后的外层where条件尤为重要,是锁定其批量更新数据的范围。
方法二:
1 2 3 4 5 6 | MERGE INTO 表2 USING 表1 ON (表2.A = 表1.A) -- 条件是 A 相同 WHEN MATCHED THEN UPDATE SET 表2.C = 表1.B -- 匹配的时候,更新 |
标签:oracle 更新两张表关联的数据
原文地址:http://blog.51cto.com/11218855/2103906