如何更新兩個表之前的不同資料呢?那麼必然存在多條資料中多個欄位的資料不同情況。下面我舉例說明:
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;