用一条SQL语句将数据表中某列更新到另一个数据表里
这次写的内容和C++无关,是一个关于SQL语句的小技巧。
1. 问题
假定在一个数据库中有2个数据表,名称分别为T1,T2,其表结构和数据内容如下:
[表T1] |
[表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 10g的数据库中,笔者经过试验证实下面的
语句可以满足要求:
Update T1 set A2 = (select A22 from T2 where A1=T2.A11) where A1=(select A11 from T2 where A1=T2.A11);
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论