位置: 编程技术 - 正文

T-SQL 查询语句的执行顺序解析(sql中查询语句)

编辑:rootadmin

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

(1)FROM (1-J) <left_table> <join_type> JOIN <right_table> on <on_predicate>

(2)WHERE <where_predicate>

(3)GROUP BY <group_by_specification>

(4)HAVING <having_predicate>

(6)ORDER BY <order_by_list>;

  每一步都会生成一个虚拟表,该虚拟表会作为下一步的输入。这些虚拟表对于调用者是不可用的,只有最后一步生成的虚拟表才会返回给调用者。如果在查询中没有指定某一个子句,则会跳过相应的步骤。接下来就简单地描述一下这些不同的逻辑步骤。

(1)FROM FROM阶段标识出查询的来源表,处理表运算符,每个表运算符也会应用一系列子阶段。例如,在联接运算中涉及的阶段是(1-J1)笛卡尔积、(1-J2)ON筛选器和(1-J3)添加外部行。FROM阶段生成虚拟表VT1。

(1-J1)笛卡尔积 这个阶段对表运算符涉及的两个表执行笛卡尔积(交叉联接),生成虚拟表VT1-J1。

(1-J2)ON筛选器 这个阶段对VT1-J1中的行根据ON子句中出现的谓语进行筛选。只有让该谓语取值为TRUE的行,才能插入VT1-J2中。

(1-J3)添加外部行 如果指定了OUTER JOIN(相对于CROSS JOIN 或 INNER JOIN),则将保留表(preserved table)中没有找到匹配的行,作为外部行添加到VT1-J2中,生成VT1-J3。

(2)WHERE 这个阶段根据在WHERE子句中出现的谓语(<where_predicate>)对于VT1中的行进行筛选。只有让谓语计算结果为TRUE的行,才会插入VT2中。

(3)GROUP BY 按照GROUP BY子句中指定的列名列表,将VT2中的行进行分组,生成VT3。

(4)HAVING 根据HAVING子句中出现的谓语(<having_predicate>)对VT3中的分组进行筛选。只有让谓语计算结果为TRUE的组,才会插入到VT4。

(5)SELECT 处理SELECT子句中的元素,生成VT5。

(5-1)计算表达式 计算SELECT列表中的表达式,生成VT5-1。

(5-2)DISTINCT 删除VT5-1中的重复行,生成VT5-2。

(5-3)TOP 根据ORDER BYi子句定义的逻辑排序,从VT5-2中选择前面指定数量或百分比的行,生成表VT5-3。

(6)ORDER BY 根据ORDER BY子句中指定的列名列表,对VT5-3中的行进行排序,生成游标VC6。

标签: sql中查询语句

本文链接地址:https://www.jiuchutong.com/biancheng/348876.html 转载请保留说明!

上一篇:学习SQL语句(强大的group by与select from模式)(sql 语句)

下一篇:sql存储过程获取汉字拼音头字母函数(sql中存储过程的用法)

  • 居民个税和非居民个税哪个高
  • 生产部的管理人员简介范文
  • 住房公积金发票
  • 增值税专用发票明细太多怎么办
  • 会计凭证审核的主要内容
  • 出资款在现金流中怎么体现
  • 所得税退税怎么办
  • 资产负债表中应收账款
  • 土地出让金返还政策文件
  • 可以向国外账户汇人民币吗
  • 审计范围包括什么内容
  • 股东捐赠给企业资金保壳
  • 质押费用计入什么科目
  • 其他应付为负数怎么处理
  • 公司购入货架如何做账
  • 代管商品物资登记制度
  • 如何理解出口退税政策
  • 个体户增值税怎么算
  • 通信服务费计入什么科目
  • 公司按月工资怎么算
  • 税前不得扣除的项目
  • 土地增值税的纳税人是在我国境内
  • 商品期货交易会计核算
  • 外购消费品已纳消费税
  • 汽车维修公司如何经营粉丝群才能让潜在客户注意到我们
  • 从租计征的税率
  • 个人银行卡转公账怎么转
  • 发票验证查询系统官网入口
  • 关于小微企业的规定
  • 发票收款人和复核人空白
  • 初级证书多长时间可以领取?
  • 汇票线下清算什么时候能到账
  • 基于php开发
  • 编译报错place 30-681
  • 鸿蒙系统怎么隐藏应用图标
  • php
  • lean in桑德伯格
  • php 调试工具
  • 分支机构分摊税款的计算
  • 约克郡在哪
  • 资产负债表是不是根据记账凭证生成的
  • thinkphp怎么用
  • print函数php
  • php cache缓存
  • Sublime Text 4 (Build 4143) 注册方法STEP BY STEP
  • jquery获取值的几种方法
  • php会员到期功能
  • 申报完成后怎么处理
  • 预收安装费的会计分录
  • 递延所得税的会计应用
  • 小规模纳税人享受小微企业优惠政策
  • 进项税额加计扣除5%账务处理
  • discuz怎么使用
  • java8 (jdk 1.8) 新特性——Lambda
  • 投资性房地产在资产负债表中的列示
  • 投资公司和控股公司关系
  • mysql错误提示
  • 新政府会计制度下的基建会计
  • 车船税去哪里交
  • 小商户怎么打发票
  • 二次加工型的企业有哪些
  • mysql解压安装教程5.7
  • windowsserver2008远程桌面怎么打开
  • solaris 创建文件
  • vs2013运行
  • win10周年版
  • nodejs 插件开发
  • 常用adb命令大全
  • angular js表达式
  • dom 和bom
  • javascript入门教学
  • bootstrap和css的关系
  • python自动化运维教程
  • python命令行在哪
  • 成都税务企业号公众号
  • 达州房管局备案查询系统
  • 12366国税网上申报
  • 从国外买东西回来卖
  • 我们是小规模纳税人,有个人所得税代扣代缴的业务吗
  • 广西怎么查社保记录
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设