欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 运维知识 > 数据库 >内容正文

数据库

你真的会玩SQL吗?简单的数据修改

发布时间:2024/1/17 数据库 43 豆豆
生活随笔 收集整理的这篇文章主要介绍了 你真的会玩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)GOselect * from Table2--3.INSERT INTO SELECT语句复制表数据Insert into Table2(a, c, d) select a,c,5 from Table1GO--4.显示更新后的结果select * from Table2GO--5.删除测试表drop TABLE Table1drop 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 Table1GO--4.显示更新后的结果select * from #Table2GO--5.删除测试表drop TABLE Table1drop TABLE #Table2

     3.delete from

    基于联接的delete,如想删除2008年5月6日以后下的订单明细

    DELETE FROM od FROM sales.orderdetails AS odJOIN 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 oJOIN sales.customers AS c ON o.custid = c.custid WHERE c.country = 'usa'

     今天内容很简单,就不做练习了,多看看文章……

    转载于:https://www.cnblogs.com/zhangs1986/p/4915124.html

    总结

    以上是生活随笔为你收集整理的你真的会玩SQL吗?简单的数据修改的全部内容,希望文章能够帮你解决所遇到的问题。

    如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。