oracle update set 多个字段,Oracle-update同时更新多个字段多个值

--创建表A,B:

create table CUX_TEST_TABLE_A (a1 varchar2(240),a2 varchar2(240),a3 varchar2(240));

create table CUX_TEST_TABLE_B (b1 varchar2(240),b2 varchar2(240),b3 varchar2(240));

--插入数据

insert into CUX_TEST_TABLE_A values('1','aa','100');

insert into CUX_TEST_TABLE_A values('2','bb','100');

insert into CUX_TEST_TABLE_A values('3','cc','');

insert into CUX_TEST_TABLE_A values('4','dd','200');

insert into CUX_TEST_TABLE_B values('1','XX','10000');

insert into CUX_TEST_TABLE_B values('2','YY','10000');

insert into CUX_TEST_TABLE_B values('4','ZZ','20000');

insert into CUX_TEST_TABLE_B values('5','KK','');

commit;

--查询表CUX_TEST_TABLE_A

380f7d7ce185ca4367a04802f97a3937.png

----查询表CUX_TEST_TABLE_B

36566681822802f91e754c4526cb2706.png

--做同时更新多个字段的update语句

UPDATE cux_test_table_a a

SET    (a.a2

,a.a3) =

(SELECT b.b2

,b.b3

FROM   cux_test_table_b b

WHERE  b.b1 = a.a1

AND    a.a3 = 100)

WHERE  EXISTS (SELECT 'X'

FROM   cux_test_table_b b

WHERE  b.b1 = a.a1   AND    a.a3 = 100);

--再次查询表CUX_TEST_TABLE_A

551fba6ce8855455aa011d888c33a3b9.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值