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;

转载于:https://www.cnblogs.com/cici-new/archive/2013/05/01/3053126.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值