当前位置: 首页 > article >正文

SQL Server中SELECT (Transact-SQL)语法定义和解释

在这里插入图片描述
语法定义:

<SELECT statement> ::=
    [ WITH { [ XMLNAMESPACES , ] [ <common_table_expression> [ , ...n ] ] } ]
    <query_expression>
    [ ORDER BY <order_by_expression> ]
    [ <FOR Clause> ]
    [ OPTION ( <query_hint> [ , ...n ] ) ]
<query_expression> ::=
    { <query_specification> | ( <query_expression> ) }
    [  { UNION [ ALL ] | EXCEPT | INTERSECT }
        <query_specification> | ( <query_expression> ) [ ...n ] ]
<query_specification> ::=
SELECT [ ALL | DISTINCT ]
    [ TOP ( expression ) [ PERCENT ] [ WITH TIES ] ]
    <select_list>
    [ INTO new_table ]
    [ FROM { <table_source> } [ , ...n ] ]
    [ WHERE <search_condition> ]
    [ <GROUP BY> ]
    [ HAVING <search_condition> ]
[ ; ]

解释:

  1. <SELECT statement>、<query_expression> 、<query_specification>等,这些用尖括号括起来的,称为术语
  2. ::=后面跟随的是对术语的解释
  3. 像这种被中括号括起来的[ WHERE <search_condition> ] [ <GROUP BY> ] [ HAVING <search_condition> ]都表示为可选元素
  4. {}被这种花括号括起来的表示必选元素,如果花括号中有|这种符号,表示只能选其一,比如这种: { UNION [ ALL ] | EXCEPT | INTERSECT }
  5. [ ...n ] 表示对前面所写元素的0到多次重复
  6. [ , ...n ] 表示对前面所写元素的0到多次重复,用逗号隔开

把上面Select语法拆分成一个最简单的查询语句
上面Select语法定义是由3个术语组成,分别是:

<query_specification> ::=
SELECT [ ALL | DISTINCT ]
    [ TOP ( expression ) [ PERCENT ] [ WITH TIES ] ]
    <select_list>
    [ INTO new_table ]
    [ FROM { <table_source> } [ , ...n ] ]
    [ WHERE <search_condition> ]
    [ <GROUP BY> ]
    [ HAVING <search_condition> ]
[ ; ]
<query_expression> ::=
    { <query_specification> | ( <query_expression> ) }
    [  { UNION [ ALL ] | EXCEPT | INTERSECT }
        <query_specification> | ( <query_expression> ) [ ...n ] ]
<SELECT statement> ::=
    [ WITH { [ XMLNAMESPACES , ] [ <common_table_expression> [ , ...n ] ] } ]
    <query_expression>
    [ ORDER BY <order_by_expression> ]
    [ <FOR Clause> ]
    [ OPTION ( <query_hint> [ , ...n ] ) ]
  1. <query_specification> 进行简化拆解,就只剩
SELECT  <select_list>
  1. <query_expression> 进行简化拆解,就只剩 { <query_specification> | ( <query_expression> ) }然后选择一个,我们把<query_specification>带入就是
SELECT  <select_list>
  1. <SELECT statement>
    进行简化拆解,就只剩<query_expression>,然后继续带入,最简查询语句就出来了
SELECT  <select_list>

由上面定义我们知道 <select_list>也是术语,他可以是一个表达式,一个值,等,或者是通过逗号分隔出来的各种表达式。


http://www.kler.cn/a/430502.html

相关文章:

  • uniapp生成h5后发布到服务器碰到的问题解决
  • 音视频入门基础:MPEG2-PS专题(2)——使用FFmpeg命令生成ps文件
  • Linux shell脚本用于常见图片png、jpg、jpeg、webp、tiff格式批量转PDF文件
  • Linux应用软件编程-多任务处理(进程)
  • 深度学习助力股市预测:LSTM、RNN和CNN模型实战解析
  • No.29 笔记 | CTF 学习干货
  • GAMES101:现代计算机图形学-笔记-10
  • MySQL触发器的使用详解
  • 【漫话机器学习系列】003.Agglomerative聚类
  • 分布式 Paxos算法 总结
  • 信息化时代的安全挑战与密评的重要性
  • 【Linux】软硬连接 | 静动态库
  • onnx文件转pytorch pt模型文件
  • 【Spark】Spark Join类型及Join实现方式
  • 使用 electron 把 vue 项目打包成客户端
  • liunx docker 部署 nacos seata sentinel
  • TCP/IP协议配置与网络实用命令
  • uniapp 弹出软键盘后打开二级页面,解决其UI布局变动
  • 同城到家预约上门服务解决方案:家政预约同城服务小程序
  • React Native 速度提升 550%
  • 流网络等价性证明:边分解后的最大流保持不变
  • vue3 setup有什么用?
  • 【优选算法篇】剥洋葱式探索:用二分查找精准定位答案(下篇)
  • 一些硬件知识【2024/12/6】
  • 【PX4飞控】二次开发1—加速度转期望姿态算法修改
  • 前端实现复制功能,Uncaught TypeError: Cannot read property ‘writeText‘ of undefined