关闭 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。

    上一篇返回首页 下一篇

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

    别人在看

    电脑屏幕不小心竖起来了?别慌,快捷键搞定

    Destoon 模板存放规则及语法参考

    Destoon系统常量与变量

    Destoon系统目录文件结构说明

    Destoon 系统安装指南

    Destoon会员公司主页模板风格添加方法

    Destoon 二次开发入门

    Microsoft 将于 2026 年 10 月终止对 Windows 11 SE 的支持

    Windows 11 存储感知如何设置?了解Windows 11 存储感知开启的好处

    Windows 11 24H2 更新灾难:系统升级了,SSD固态盘不见了...

    IT头条

    Synology 更新 ActiveProtect Manager 1.1 以增强企业网络弹性和合规性

    00:43

    新的 Rubrik Agent Cloud 加速了可信的企业 AI 代理部署

    00:34

    宇树科技 G1人形机器人,拉动一辆重达1.4吨的汽车

    00:21

    Cloudera 调查发现,96% 的企业已将 AI 集成到核心业务流程中,这表明 AI 已从竞争优势转变为强制性实践

    02:05

    投资者反对马斯克 1 万亿美元薪酬方案,要求重组特斯拉董事会

    01:18

    技术热点

    大型网站的 HTTPS 实践(三):基于协议和配置的优化

    ubuntu下右键菜单添加新建word、excel文档等快捷方式

    Sublime Text 简明教程

    用户定义SQL Server函数的描述

    怎么在windows 7开始菜单中添加下载选项?

    SQL Server 2016将有哪些功能改进?

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

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