sql查询点滴记录
时间:2024-01-14 14:30:19
也不一定,以前从来没有深入的研究过sql查询,最近买了一本T-SQL查询的书,把以前忽视的问题都记录一下
以前一直模模糊糊的把sqlserver作为关系数据库,里面就是以表的方式进行数据的关系化话管理,后来有些SQL语句看着怪怪的,也没怎么管
其实
“写好sql,需要的是一种面向声明和集合的思维方式,而不是面向过程的(集合是重点)”(PS:数据库里面的表就是一个集合,集合是无序的!)
以前没太注意过sql语句执行时的逻辑顺序,在研究linq时,linq强调了sql语句的执行顺序,在看书时也留意了一下
(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>
|(1-a) <left_table> <apply_type> apply <right_table_expression> as <alias>
|(1-p) <left_table> pivot (<pivot_specification>) as <alias>
|(1-u) <left_table> unpivot (<unpivot_specification>) as <alias>
(2) where <where_predicate>
(3) group by <group_by_specification>
(4) having <having_predicate>
(6) order by <order_by_list>
可以看到
第一个阶段是from :标识出查询的来源,处理表(集合)运算符
第二个阶段是where根据谓词(查询条件)进行刷选
第三个阶段是gruop by 根据指定的列表名进行分组
第四个阶段是having 根据having中出现的谓词进行刷选
第五个阶段是select
第六各阶段是order by根据指定列进行排序
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
js表单检测数字
解决Windows 7下安装Oracle 11g相关问题的方法
![](https://img.aspxhome.com/file/2023/5/67535_0s.jpg)
Python入门篇之字符串
Java基于redis和mysql实现简单的秒杀(附demo)
![](https://img.aspxhome.com/file/2023/0/78000_0s.jpg)
分享Python 中的 7 种交叉验证方法
![](https://img.aspxhome.com/file/2023/1/81481_0s.png)
Window10下python3.7 安装与卸载教程图解
![](https://img.aspxhome.com/file/2023/5/105565_0s.jpg)
Python找出列表中出现次数最多的元素三种方式
centos 安装mysql中遇到问题的解决办法
XML+ JS创建树形菜单
SQL Server中通过扩展存储过程实现数据库的远程备份与恢复
Vue+Java+Base64实现条码解析的示例
Python 存储字符串时节省空间的方法
python搭建虚拟环境的步骤详解
Python中match语句的详细用法实例
![](https://img.aspxhome.com/file/2023/7/60517_0s.png)
最详细的python工具Anaconda+Pycharm安装教程
![](https://img.aspxhome.com/file/2023/2/75262_0s.png)
Python实现word2Vec model过程解析
![](https://img.aspxhome.com/file/2023/4/63254_0s.jpg)
python 如何做一个识别率百分百的OCR
![](https://img.aspxhome.com/file/2023/4/60984_0s.png)