經常會遇到一個表需要根據另一個表數據來更新數據,總結了核心的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