- 1、本文档共104页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
大型数据库第3章transactsql语言要点
第三节 增强功能 Microsoft SQL Server 2008在之前版本的基础上对Teansact-SQL进行了进一步增强,使得Transacl-SQL语介的功能更加强大,也简化了数据库管理员的操作。 1.Transact-SQL行构造器 T-SQL行构造器(Row Constructors)用来在INSERT语句中一次性插入多行数据。例如: 例:INSert into student values(201207001,赵强,男,20,CS,2012), ( 201307002,刘秦,女,21,MA,2013) 2.MERGE语句 这个新增的 Transaction SQL 语句在一个基于源数据连接结果集的目标表上执行INSERT、UPDATE 和 DELETE操作。该语法允许您将一个数据源连接到目标表或视图上。然后在连接后的结果集上执行多种操作。 示例:在一条SQL语句中使用WHERE在一张表上执行UPDATE和DELETE操作。 USE AdventureWorks; GO MERGE Production.ProductInventory AS pi USING (SELECT ProductID, SUM(OrderQty) FROM Sales.SalesOrderDetail sod JOIN Sales.SalesOrderHeader soh ON sod.SalesOrderID = soh.SalesOrderID AND soh.OrderDate = GETDATE() GROUP BY ProductID) AS src (ProductID, OrderQty) ON (pi.ProductID = src.ProductID) WHEN MATCHED AND pi.Quantity - src.OrderQty 0 THEN UPDATE SET pi.Quantity = pi.Quantity - src.OrderQty WHEN MATCHED AND pi.Quantity - src.OrderQty = 0 THEN DELETE; 这个示例是一个非常典型的销售定货库存问题。这个示例很简单,表达的意思就是:如果某一个产品产生了销售定单数据,则将其对应的产品库存除去该销售定单所产生的数量,如果当前库存数量与该销售定单数量相同,则从库存表中删除该产品的库存纪录。 是SQL Server2008下新增的语句,功能:根据一个源数据表对另一个数据表进行确定性的插入、更新和删除等复杂操作。 对两个表进行信息同步时,有三步,处理需要插入目标数据包的新行;处理需要更新的已存在的行,删除不再使用的旧行。 模板: Merge [target] t Using [souce] s on t.id=s.id When matched then update t.name=s.name,t.age=s.age When not matched by target then insert values(id,name,age) When not matched BY SOURCE then delete; MERGE子句用于指定作为INSERT,UPDATE或DELE丁E操作目标的表或视图; USING子句用于指定要与目标联接的数据源; ON子句用于指定决定目标与源匹配位置的联接条件; WHEN子句用于根据ON子句的结果指定要执行的操作。 例:跟据student表的数据更新student2表的数据。 merge [student2] s2 Using [student] s on s2.sno=s.sno When matched then update set s2.sname=s.sname When not matched by target then insert values(sno,sname) When not matched BY SOURCE then delete; 例:在学号相同的情况下,想删除年龄大于30的学生的信息。 merge [student2] s2 Using [student] s on s2.sno=s.sno When matched and s2.sage30 then delete When not matched by target then insert values(sno,sname,sage); 我们看到,利用 MERGE 语句可以将复杂的 SQL 语句简化。它比起 IF、CASE 等更加灵活和强大。 5.10 本章小结 本章全面讲述了Transact-SQL语言的基本功能。首先,介
您可能关注的文档
- 多会议室方案说明.doc
- 海绵城市研究.ppt
- 多功能电烤炉.doc
- 多台并联水泵运行台数切换方式与效率的关系.docx
- 多回路架空送电线路耐雷水平分析.doc
- 多媒体信息在计算机中的表示.ppt
- 多媒体技术原理及应用(马华东第二版)6第六章.ppt
- 海阳新希望六和饲料有限公司六和饲料响报告表9.9.doc
- 多媒体教案-材料物理性能学-01-固体中电子能量结构和状态-2015-au.ppt
- 多传感器数据融合技术.ppt
- 2025届衡阳市第八中学高三一诊考试物理试卷含解析.doc
- 2025届湖南省娄底市双峰一中等五校重点中学高三第二次诊断性检测物理试卷含解析.doc
- 天水市第一中学2025届高三第二次联考物理试卷含解析.doc
- 2025届金华市重点中学高三考前热身物理试卷含解析.doc
- 2025届北京市石景山区第九中学高三第四次模拟考试物理试卷含解析.doc
- 江苏扬州市2025届高三第一次模拟考试物理试卷含解析.doc
- 2025届江苏省南通市高级中学高考物理五模试卷含解析.doc
- 广东省清远市华侨中学2025届高三第一次调研测试物理试卷含解析.doc
- 辽宁省凤城市2025届高三第五次模拟考试物理试卷含解析.doc
- 内蒙古巴彦淖尔市重点中学2025届高考仿真卷物理试卷含解析.doc
文档评论(0)