用一个表字段更新另一个表字段三种方法

--Oracle 用一个表字段更新另一个表字段三种方法
--1、建测试表如下
prompt PL/SQL Developer import file
prompt Created on 2016年7月29日 by wsq
set feedback off
set define off
prompt Disabling triggers for T_A...
alter table T_A disable all triggers;
prompt Disabling triggers for T_B...
alter table T_B disable all triggers;
prompt Truncating T_B...
truncate table T_B;
prompt Truncating T_A...
truncate table T_A;
prompt Loading T_A...
insert into T_A (id, name, demo)
values (1, 'aaa', 'bbb');
insert into T_A (id, name, demo)
values (2, 'ccc', 'ddd');
insert into T_A (id, name, demo)
values (3, 'eee', 'fff');
commit;
prompt 3 records loaded
prompt Loading T_B...
insert into T_B (id, name, demo)
values (1, null, null);
insert into T_B (id, name, demo)
values (2, null, null);
insert into T_B (id, name, demo)
values (3, null, null);
commit;
prompt 3 records loaded
prompt Enabling triggers for T_A...
alter table T_A enable all triggers;
prompt Enabling triggers for T_B...
alter table T_B enable all triggers;
set feedback on
set define on
prompt Done.
--2.方法一
UPDATE T_B B
   SET B.NAME =
       (SELECT NAME FROM T_A A WHERE A.ID= B.ID),
       B.DEMO =
       (SELECT DEMO FROM T_A A WHERE A.ID = B.ID);
--3.方法二
update T_B B
   SET (name, demo) =
       (SELECT name, demo FROM T_A A WHERE A.ID = B.ID)
--4.方法三
merge into T_B B
using T_A A
on (B.ID = A.ID)
when matched then
  update set B.NAME = A.NAME, B.DEMO = A.DEMO
  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

冷月宫主

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值