用一条SQL语句将数据表中某列更新到另一个数据表里

用一条SQL语句将数据表中某列更新到另一个数据表里

需求:将一个客户表中的客户ID转换为另一表中与之名字相同的客户记录的ID,从而使同一客户在两个表中的ID也相同

 

UPDATE    ic_all

SET              customer_id =

                          (SELECT     CUST_ID

                            FROM          COAL_CUST

                            WHERE      (ic_all.customer_name = CUST_NAME))

WHERE     (customer_name =

                          (SELECT     CUST_NAME

                            FROM          COAL_CUST AS COAL_CUST_1

                            WHERE      (ic_all.customer_name = CUST_NAME)))

 

1.       问题

      假定在一个数据库中有2个数据表,名称分别为T1,T2,其表结构和数据内容如下:

 

 

A1

A2

A3

1

11

21

2

12

22

3

13

23

[表T1]

 

 

A11

A22

1

3

2

4

[表T2]

 

其中T1的A1列非空且唯一;T2的A11列非空且唯一。

 

需求:当T1中的A1与T2中的A11相等时,把T1中A2列的数据更新为T2中A22列。

上例中T1更新后应该得到如下结果:

A1

A2

A3

1

3

21

2

4

22

3

13

23

[T1更新后]

 

2.       一般解法

实现上述需求有多种方法,最直接的一种是逐条更新,如下:

Update T1 set A2 = 3 where A1 =1;

Update T1 set A2 = 4 where A1 =2;

......

或者写个存储过程,内部用循环的方法实现,在此就不再列举代码了。

3.       新解法

这些方法共同的缺点一是每更新一条记录都需要一个update操作,导致执行速度慢;另一个是要写的语句很多,很烦琐。

新方法用一条Update就实现全部需求。在Oracle <?xml:namespace prefix = st1 ns = "urn:schemas-microsoft-com:office:smarttags" /><?xml:namespace prefix = st1 /><?xml:namespace prefix = st1 /><?xml:namespace prefix = st1 /><?xml:namespace prefix = st1 /><?xml:namespace prefix = st1 />的数据库中,笔者经过试验证实下面的语句可以满足要求:

Update T1 set A2 = (select A22 from T2 where A1=T2.A11) where A1=(select A11 from T2 where A1=T2.A11);

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值