你真的会玩SQL吗?简单的数据修改
你真的会玩SQL吗?系列文章
- 你真的会玩SQL吗?之逻辑查询处理阶段
- 你真的会玩SQL吗?和平大使 内连接、外连接
- 你真的会玩SQL吗?三范式、数据完整性
- 你真的会玩SQL吗?查询指定节点及其所有父节点的方法
- 你真的会玩SQL吗?让人晕头转向的三值逻辑
- 你真的会玩SQL吗?EXISTS和IN之间的区别
- 你真的会玩SQL吗?无处不在的子查询
- 你真的会玩SQL吗?Case也疯狂
- 你真的会玩SQL吗?表表达式,排名函数
- 你真的会玩SQL吗?简单的数据修改
- 你真的会玩SQL吗?你所不知道的 数据聚合
- 你真的会玩SQL吗?透视转换的艺术
- 你真的会玩SQL吗?冷落的Top和Apply
- 你真的会玩SQL吗?实用函数方法汇总
- 你真的会玩SQL吗?玩爆你的数据报表之存储过程编写(上)
- 你真的会玩SQL吗?玩爆你的数据报表之存储过程编写(下)
项目会有种需要将A表中的部分字段与B表中的部分字段联合查询后保存到C表,或更新到C表,那怎么实现呢?
- select into
- insert select
- delete from
- update from
- insert exec 语句可以把存储过程或动态批处理返回的结果保存到现有表中(这里暂时先不讲)
Insert是T-sql中常用语句,Insert INTO table(field1,field2,…) values(value1,value2,…)这种形式的在应用程序开发中必不可少。但我们在开发、测试过程中,经常会遇到需要表复制的情况,如将一个table1的数据的部分字段复制到table2中,或者将整个table1复制到table2中,这时候我们就要使用SELECT INTO 和 INSERT INTO SELECT 表复制语句了。
1.INSERT INTO SELECT语句
语句形式为:Insert into Table2(field1,field2,…) select value1,value2,… from Table1
要求目标表Table2必须存在,由于目标表Table2已经存在,所以我们除了插入源表Table1的字段外,还可以插入常量。示例如下:
--1.创建测试表 create TABLE Table1 ( a varchar(10), b varchar(10), c varchar(10), CONSTRAINT [PK_Table1] PRIMARY KEY CLUSTERED ( a ASC ) ) ON [PRIMARY] create TABLE Table2 ( a varchar(10), c varchar(10), d int, CONSTRAINT [PK_Table2] PRIMARY KEY CLUSTERED ( a ASC ) ) ON [PRIMARY] GO --2.创建测试数据 Insert into Table1 values('赵','asds','90') Insert into Table1 values('钱','asds','100') Insert into Table1 values('孙','asds','80') Insert into Table1 values('李','asds',null) GO select * from Table2 --3.INSERT INTO SELECT语句复制表数据 Insert into Table2(a, c, d) select a,c,5 from Table1 GO --4.显示更新后的结果 select * from Table2 GO --5.删除测试表 drop TABLE Table1 drop TABLE Table2
2.SELECT INTO FROM语句
语句形式为:SELECT vale1, value2 into #Table2 from Table1
要求目标表Table2不存在,因为在插入时会自动创建表Table2,并将Table1中指定字段数据复制到临时表Table2中。示例如下:
--1.创建测试表 create TABLE Table1 ( a varchar(10), b varchar(10), c varchar(10), CONSTRAINT [PK_Table1] PRIMARY KEY CLUSTERED ( a ASC ) ) ON [PRIMARY] GO --2.创建测试数据 Insert into Table1 values('赵','asds','90') Insert into Table1 values('钱','asds','100') Insert into Table1 values('孙','asds','80') Insert into Table1 values('李','asds',null) GO --3.SELECT INTO FROM语句创建表Table2并复制数据 select a,c INTO #Table2 from Table1 GO --4.显示更新后的结果 select * from #Table2 GO --5.删除测试表 drop TABLE Table1 drop TABLE #Table2
3.delete from
基于联接的delete,如想删除2008年5月6日以后下的订单明细
DELETE FROM od FROM sales.orderdetails AS od JOIN sales.orders AS o ON od.orderid = o.orderid WHERE o.orderdate >= '20080506'
4.update from
基于联接的update,如想更新由usa客户所下单的发货信息,用customers表中客户的country,region,city改写shipcountry,shipregion,shipcity
UPDATE o SET shipcountry = c.country , shipregion = c.region , shipcity = c.city FROM sales.orders AS o JOIN sales.customers AS c ON o.custid = c.custid WHERE c.country = 'usa'
今天内容很简单,就不做练习了,多看看文章……
作者:欢醉
公众号【一个码农的日常】 技术群:319931204 1号群: 437802986 2号群: 340250479
出处:http://zhangs1986.cnblogs.com/
码云:https://gitee.com/huanzui
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
原文地址:http://www.cnblogs.com/zhangs1986/p/4915124.html
相关推荐
-
CentOS7.6使用yum配置lnmp环境 服务器
2019-10-13
-
数据库知识整理 服务器
2019-10-15
-
多语言业务错误日志收集监控工具Sentry 安装与使用 服务器
2019-8-9
-
Redis单点安装,注册为系统服务,开机启动 服务器
2020-6-21
-
针对innodb_flush_method参数的理解和对比测试(mycat+mysql) 服务器
2020-5-31
-
尝试 H2o 做机器学习 服务器
2019-2-24
-
在 Linux 上使用 Nginx 和 Gunicorn 托管 Django 应用 服务器
2019-3-6
-
MariaDB Window Functions窗口函数分组取TOP N记录 服务器
2019-9-11
-
[喵咪大数据]Hadoop集群模式 服务器
2020-6-21
-
Apache Ignite事务架构:2阶段提交协议 服务器
2020-6-13