如何更新两个表之前的不同数据呢?那么必然存在多条数据中多个字段的数据不同情况。下面我举例说明:
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 into tb2 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;