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

来源:互联网 发布:淘宝官方自营店可靠吗 编辑:程序博客网 时间:2024/04/29 21:42

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

 

       这次写的内容和C++无关,是一个关于SQL语句的小技巧。

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就实现全部需求。在Oracle10g的数据库中,笔者经过试验证实下面的语句可以满足要求:

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

 

 

 

原创粉丝点击