用一条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);
- 用一条SQL语句将数据表中某列更新到另一个数据表里
- 用一条SQL语句将数据表中某列更新到另一个数据表里
- 用一条SQL语句将数据表中某列更新到另一个数据表里
- 用一条SQL语句根据条件将数据表中某几列更新到另一个数据表对应有列
- MySql update inner join!MySql跨表更新 多表update sql语句?如何将select出来的部分数据update到另一个表里面?
- MySql update inner join!MySql跨表更新 多表update sql语句?如何将select出来的部分数据update到另一个表里面?
- 一条sql语句(关于将一个表里的数据汇总,更新数据库中的另外一张表的列值
- mysql 将一个表里面的数据更新到另一个表里面
- 一张表里的数据更新到另一个表里
- sql 中如何将A表的数据更新到B表中,数据表备份语句
- 将一个表的数据的某些字段更新到另一个表里面的某些字段
- mysql里将一张表里一列的数据更新到另一个表的一列上
- mysql 如何用一条SQL将一张表里的数据插入到另一张表
- Sql语句把一个表的某几列的数据存到另一个表里的方法
- mysql 如何用一条SQL将一张表里的数据插入到另一张表 3个例子
- 怎样用SQL Server 2008 SQL语句将Excel数据导入到数据库里指定的表里面?(
- 怎样用SQL Server 2008 SQL语句将Excel数据导入到数据库里指定的表里面
- Sql 两个数据库复制数据表到另一个数据
- 纪念一下首个自己搭建起来的ftp(非技术)
- JAVA 位操作详解
- c/c++编写window服务的授权服务(一)
- C# iphone MontTouch UIPicker 的使用
- 利用bochs调试内核
- 用一条SQL语句将数据表中某列更新到另一个数据表里
- c/c++编写window服务的授权服务(二)
- ASP.NET Padding Oracle Vulnerablitity
- c/c++编写window服务的授权服务(三)
- 用最短的时间完成你的工作
- c/c++编写window服务的授权服务(四)
- Codeforces Testing Round #3
- 关于PHP代码安全
- UNIX上C++程序设计守则(信号和线程)