ORACLE 批量修改多列多行的数据
今天有人问我一个问题,如何根据一个表更新另一个表的多行多列的数据,数据字段较多。为便于其他朋友能够快速处理类似的问题,我简单进行了归纳,希望有所帮助。如何更新两个表之前的不同数据呢?那么必然存在多条数据中多个字段的数据不同情况。下面我举例说明:
1、创建表
[*]create table tb1
[*](id varchar2(10),
[*]xm varchar2(10),
[*]xb varchar2(10));
[*]
[*]create table tb2
[*](id varchar2(10),
[*]xm varchar2(10),
[*]xb varchar2(10));
2、插入测试数据
[*]insert into tb1 values('1','xx','xx');
[*]insert into tb1 values('2','yy','yy');
[*]insert into tb1 values('3','zz','zz');
[*]insert into tb1 values('5','mm','mm');
[*]
[*]insert into tb2 values('1','1','1');
[*]insert into tb2 values('2','2','2');
[*]insert into tb2 values('3','3','3');
[*]insert intotb2 values('4','4','4');
3、下面提供两种方式,执行以下SQL语句,并查看结果:
[*]update tb2 set xm=(select xm from tb1 where tb1.id=tb2.id),xb=(select xb from tb1 where tb1.id=tb2.id) where id in(select id from tb1);
[*]
[*]update tb2 set(xm,xb)=(select xm,xb from tb1 where tb1.id=tb2.id)where id in(select id from tb1);
4、注意以上红色标记的SQL语句,请自行去掉后,做下测试,会有什么不同。
5、测试完,请删除表。养成良好习惯。
[*]drop table tb1;
[*]drop table tb2;
其他数据库(如sqlserver)原理类似。另,还可以添加过滤条件,由于时间问题,不再一一举例,望见谅。
页:
[1]