关闭 x
IT技术网
    技 采 号
    ITJS.cn - 技术改变世界
    • 实用工具
    • 菜鸟教程
    IT采购网 中国存储网 科技号 CIO智库

    IT技术网

    IT采购网
    • 首页
    • 行业资讯
    • 系统运维
      • 操作系统
        • Windows
        • Linux
        • Mac OS
      • 数据库
        • MySQL
        • Oracle
        • SQL Server
      • 网站建设
    • 人工智能
    • 半导体芯片
    • 笔记本电脑
    • 智能手机
    • 智能汽车
    • 编程语言
    IT技术网 - ITJS.CN
    首页 » SQL Server »SQL Server 2008逻辑查询的处理步骤有哪些?

    SQL Server 2008逻辑查询的处理步骤有哪些?

    2010-07-19 10:55:00 出处:ITJS
    分享

    此文章主要向大家讲述的是SQL Server 2008逻辑查询的正确而处理步骤,大家是否对《SQL Server 2005技术内幕T-SQL查询》 有所了解,博文组织翻译的,作者是SQL Server数据库方面的MVP Kalen Delaney)。

    最近我则刚刚收到了微软最有价值专家项目组寄来的该书的SQL Server 2008英文版本-《Inside Microsoft SQL Server 2008:T-SQL Querying》(http://www.microsoft.com/learning/en/us/book.aspx ID=12804&locale=en-us),大致翻了一下,发现内容变动不少,既有新增的章节,也有基于SQL Server 2005或2008新技术重新书写的SQL查询示例。

    SQL Server 2008逻辑查询处理步骤方面给大家介绍一下两本书之间的差异吧,因为我也在刚开始阅读,以后逐步给大家介绍。

    我们知道,查询的逻辑处理过程是分阶段完成的,每个阶段都会产生一个虚拟表,该虚拟表会作为下一个阶段的输入。但是,这些过程中间阶段生成的虚拟表对于查询用户是不可用的,只有最后阶段所生成的虚拟表(即查询结果)才返回给查询用户。

    在该书的SQL Server 2005版本中,将一个联接查询的逻辑SQL Server 2008逻辑查询处理分为了10个步骤:

    (8) SELECT (9) DISTINCT (11) <TOP_specification> <select_list>

    (1) FROM <left_table>

    (3) <join_type> JOIN <right_table>

    (2) ON <join_condition>

    (4) WHERE <where_condition>

    (5) GROUP BY <group_by_list>

    (6) WITH {CUBE | ROLLUP}

    (7) HAVING <having_condition>

    (10) ORDER BY <order_by_list>

    而在SQL Server 2008版本中,则对逻辑阶段的描述扩展到了所有的逻辑语句,而不仅仅是联接SQL Server 2008逻辑查询处理,如APPLY、PIVOT等。按这种分类方式,将逻辑步骤分成了6部分,部分步骤中包含了子步骤。

    (5)SELECT (5-2)DISTINCT (5-3)<TOP_specification> (5-1)<select_list>

    (1)FROM (1-J) <left_table> <join_type> JOIN <right_table> ON <join_condition>

    |(1-A) <left_table> <apply_type> APPLY <right_table_expression> AS <alias>

    |(1-P) <left_table> PIVOT(<pivot_specifications>) AS <alias>

    |(1-U) <left_table> UNPIVOT(<unpivot_specifications>) AS <alias>

    (2)WHERE <where_condition>

    (3)GROUP BY <group_by_list> (3-CR)WITH {CUBE | ROLLUP}

    (4)HAVING <having_condition>

    (6)ORDER BY <order_by_list>

    下图更详细地描述了各个SQL Server 2008逻辑查询处理步骤的流程。

    这种步骤分类相比2005版本而言更加全面和具体。上面步骤中的3-CR是我添加上去的,我觉得这样的描述更加全面。3-CR中的WITH ROLLUP和WITH CUBE参数,在SQL Server 2008中已经被GROUP BY子句的GROUPING SETS、ROLLUP和CUBE运算符代替,不再推荐使用不符合ISO标准的WITH ROLLUP、WITH CUBE和ALL语法。但是,这并不影响逻辑处理的顺序。

    下面是对逻辑处理过程中各个步骤的说明,请注意虚拟表(VTn)的生成步骤:

    · 步骤1(FROM):该步骤中用于验证查询的源表,并处理表操作符。每个表操作符应用于一系列子步骤。例如,在上面用于联接的(1-J)步骤中会涉及如下的子步骤。最终这些子步骤完成后,将生成虚拟表VT1。

    Ø (1-J1):执行left_table和right_table两个表的交叉联接(笛卡儿乘积),生成虚拟表VT1-J1;

    Ø (1-J2):对笛卡儿乘积应用ON筛选器,生成虚拟表VT1-J2;

    Ø (1-J3):假如是外部联接,会在该步骤中将被ON筛选掉的外部行添加到VT1-J2中,生成VT1-J3。否则,将跳过该步骤。

    · 步骤2(WHERE):对VT1应用WHERE筛选器,将符合筛选条件的行插入到VT2中。

    · 步骤3(GROUP BY):按GROUP BY子句中的列列表对VT2中的行分组,生成VT3。假如语句中包含WITH CUBE或WITH ROLLUP,则将分组统计结果再次加总后插入VT3,生成VT3-RC。

    · 步骤4(HAVING):对VT3应用HAVING筛选器,将符合筛选条件的行插入到VT4。

    · 步骤5(SELECT):SQL Server 2008逻辑查询处理SELECT子句中的元素,生成VT5。

    u (5-1)计算表达式:该步骤计算SELECT列表中的表达式,生成VT5-1;

    u (5-2)DISTINCT:从VT5-1中移除重复行,生成VT5-2;

    u (5-3)TOP:该步骤根据ORDER BY子句中指定的排序规则,从VT5-2的开始处筛选出指定数量或比例的行。

    · 步骤6(ORDER BY):该步骤对VT5-3中的行按ORDER BY子句中的列列表进行排序,生成一个游标VC6。

    上一篇返回首页 下一篇

    声明: 此文观点不代表本站立场;转载务必保留本文链接;版权疑问请联系我们。

    别人在看

    Edge浏览器百度被劫持/篡改怎么办,地址后边跟着尾巴#tn=68018901_7_oem_dg

    Google Chrome 在 iPhone 上新增了 Safari 数据导入选项

    Windows 11专业版 KMS工具激活产品密钥的方法

    DEDECMS安全策略官方出品

    Microsoft Text Input Application 可以关闭吗?

    新版本QQ如何关闭自带的浏览器?

    C++编程语言中continue的用法和功能,附举例示范代码

    c++ map 的数据结构、基本操作以及其在实际应用中的使用。

    C语言如何避免内存泄漏、缓冲区溢出、空指针解引用等常见的安全问题

    C语言中的break语句详解

    IT头条

    马斯克2026最新采访总结:2040年,全球机器人数量将突破100亿台

    23:52

    专家解读|规范人工智能前沿业态健康发展的新探索:解读《人工智能拟人化互动服务管理暂行办法》

    00:54

    用至强 6高存力搞定MoE卸载!

    17:53

    美国将允许英伟达向中国“经批准的客户”出售H200 GPU

    02:08

    苹果与微信就15%手续费达成一致?腾讯未置可否

    22:00

    技术热点

    PHP 和 Node.js 的10项对比挑战

    Javascript闭包深入解析及实现方法

    windows 7、windows 8.1手动增加右键菜单功能技巧

    MYSQL出错代码大汇总

    windows 7假死机怎么办 windows 7系统假死机的原因以及解决方法

    Ubuntu(Linux)下配置IP地址的方法

      友情链接:
    • IT采购网
    • 科技号
    • 中国存储网
    • 存储网
    • 半导体联盟
    • 医疗软件网
    • 软件中国
    • ITbrand
    • 采购中国
    • CIO智库
    • 考研题库
    • 法务网
    • AI工具网
    • 电子芯片网
    • 安全库
    • 隐私保护
    • 版权申明
    • 联系我们
    IT技术网 版权所有 © 2020-2025,京ICP备14047533号-20,Power by OK设计网

    在上方输入关键词后,回车键 开始搜索。Esc键 取消该搜索窗口。