用一条SQL语句将数据表中某列更新到另一个数据表里
2014-01-06 13:46
337 查看
用一条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);
#Sql Server
转载自http://hi.baidu.com/prometheus2008/item/d4185c5cff30b317abf6d77a
相关文章推荐
- 用一条SQL语句将数据表中某列更新到另一个数据表里
- 用一条SQL语句根据条件将数据表中某几列更新到另一个数据表对应有列
- 用一条SQL语句将数据表中某列更新到另一个数据表里
- 一条sql语句(关于将一个表里的数据汇总,更新数据库中的另外一张表的列值
- 【SQL】oracle 一条语句更新两行,decode函数交换两行数据,实例教程
- Mysql 一条SQL语句实现批量更新数据,update结合case、when和then的使用案例
- MySql update inner join!MySql跨表更新 多表update sql语句?如何将select出来的部分数据update到另一个表里面?
- Mysql 一条SQL语句实现批量更新数据,update结合case、when和then的使用案例
- 用一条SQL语句,同时更新两个表中的数据
- Mysql 根据一个表数据更新另一个表的某些字段(sql语句)
- Mysql 一条SQL语句实现批量更新数据,update结合case、when和then的使用案例
- Java大牛养成记——一条SQL语句更新同一张表中的两条数据
- MySql update inner join!MySql跨表更新 多表update sql语句?如何将select出来的部分数据update到另一个表里面?
- MySql update inner join!MySql跨表更新 多表update sql语句?如何将select出来的部分数据update到另一个表里面?
- Mysql 一条SQL语句实现批量更新数据,update结合case、when和then的使用案例
- Mysql 一条SQL语句实现批量更新数据,update结合case、when和then的使用案例
- MySql update inner join!MySql跨表更新 多表update sql语句?如何将select出来的部分数据update到另一个表里面?
- 怎样一条SQL语句统计该年每月的数据个数
- 在SQL语句insert into中,数据来自用户页面的输入和另一个表中的命令行写法!
- 一条SQL语句 插入多条数据