宜信同城网交流论坛

 找回密码
 立即注册
开启左侧

Oracle两表关联更新三种方式

[复制链接]
发表于 2023-3-2 19:25:37 | 显示全部楼层 |阅读模式 来自 LAN

创建如下表数据

select * from t1 ;

0da8c6486eda62895651608feb3ad984.png

select * from t2;

be44f6b43089d878fa4e921010d73e42.png

现需求:参照T2表,修改T1表,修改条件为两表的fname列内容一致。

方式1. update

UPDATE T1 
SET T1.FMONEY = (select T2.FMONEY from t2 where T2.FNAME = T1.FNAME)
WHERE EXISTS(SELECT 1 FROM T2 WHERE T2.FNAME = T1.FNAME);

fee63a601a1f704571ef9e13a233582e.png

方式2. 内联视图更新

UPDATE (
select t1.fmoney  fmoney1,t2.fmoney  fmoney2 from t1,t2 where t1.fname = t2.fname
)t
set fmoney1 =fmoney2;

方式3. merge更新

merge into t1
using (select t2.fname,t2.fmoney from t2) t
on (t.fname = t1.fname)
when matched then 
update  set t1.fmoney = t.fmoney;

未经允许不得转载:王超博客 » Oracle两表关联更新三种方式

宜信网交流论坛 - 版权声明 1、在发表言论时,请遵守当地法律法规。主题所有言论纯属个人意见,与本站立场无关。
2、本站所有主题由作者发表,作者享有帖子相关版权,其他单位或个人使用、转载或引用本文时必须征得作者同意并注明来源于宜信网
3、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意。
4、帖子不遵守当地法律法规、广告、人身攻击等情况时,宜信网管理人员有权不事先通知发贴者而删除本文。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|宜信同城网交流论坛 ( 闽ICP备19021048号 )|站点地图

GMT+8, 2026-3-27 10:06 , Processed in 0.150000 second(s), 12 queries , Redis On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表