经常会遇到一个表需要根据另一个表数据来更新数据,总结了核心的sql脚本命令如下:
A表如下
x y
--------------
ka da
kb db
kc dc
kd dd
B表
x y
--------------
ka da
kc db
kd dc
kf dd
1. 使用for语句循环更新
begin
for dt in (select * from a inner join b on a.x = b.x) loop
update a set a.y = b.y where dt.x = a.x;
end loop;
end;
2. 使用from子句更新
update a set a.y = b.y from a,b where a.x = b.x
或者
update a set a.y = b.y from a inner join b on a.x = b.x