ORACLE 批量修改多列多行的数据 转 http://5icto.blog.51cto.com/3431949/714387

如何更新两个表之前的不同数据呢?那么必然存在多条数据中多个字段的数据不同情况。下面我举例说明:

1、创建表

  1. create table tb1  
  2. (id varchar2(10),  
  3. xm varchar2(10),  
  4. xb varchar2(10));  
  5.  
  6. create table tb2  
  7. (id varchar2(10),  
  8. xm varchar2(10),  
  9. xb varchar2(10)); 

2、插入测试数据

  1. insert into tb1 values('1','xx','xx');  
  2. insert into tb1 values('2','yy','yy');  
  3. insert into tb1 values('3','zz','zz');  
  4. insert into tb1 values('5','mm','mm');  
  5.  
  6. insert into tb2 values('1','1','1');  
  7. insert into tb2 values('2','2','2');  
  8. insert into tb2 values('3','3','3');  
  9. insert into  tb2 values('4','4','4');

3、下面提供两种方式,执行以下SQL语句,并查看结果:

 

  1. 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);  
  2.  
  3. 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、测试完,请删除表。养成良好习惯。

    1. drop table tb1;  
    2. drop table tb2;
posted @ 2013-05-01 13:35  王超_cc  阅读(381)  评论(0编辑  收藏  举报