编写SQL查询的关键—SQL语句的执行顺序
作者 佚名技术
来源 数据库编程
浏览
发布时间 2012-03-22
编写 SQL 语句是每个程序员应该具备的基本功。在实际开发过程中,需要编写比较复杂的 SQL 查询语句是必不可少的,但很多 SQL 书籍上不是简单的介绍一下就是出最终的查询语句,编写复杂 SQL 查询的具体思路却没有多少介绍,这不能不说是一种巨大的遗憾 , 看着一串无比复杂的 SQL 语句,没有掌握方法的话谁看了都会头晕 ^-^ 回忆一下学习编程语言的经历( C++,java 等),我们一般都是先学习变量的定义,然后是流程控制语句,接着是函数,类等等。但我们在学习 SQL , SQL 书籍上都普遍忽略了一个重要的方面: SQL 语句的执行顺序。 不知道是什么原因,这一点确实没被多少书籍提过。掌握了SQL语句的执行顺序的规律,就能较轻松的编写出复杂的 SQL 查询。 SQL 语句的执行顺序如下: 1 、 from 子句组装来自不同数据源的数据; 2 、 where 子句基于指定的条件对记录行进行筛选; 3 、 group by 子句将数据划分为多个分组; 4 、使用聚集函数进行计算; 5 、使用 having 子句筛选分组; 6 、计算所有的表达式; 7 、使用 order by 对结果集进行排序。 下面举一个简单的例子举例说明,假设有以下一张表 student : ID Name Age 1 Tom 23 2 Jack 25 3 Lucy 15 4 Anay 18 5 Bobby 21 要求通过 SQL 语句把年龄大于 20 的学生姓名查出来 SQL 语句如下: Select name From student Where age>20 结果是: Tom Jack Bobby 那对于这个简单的 SQL 语句,执行顺序是怎么样的呢? 1. from 子句组装来自不同数据源的数据,简单点来说就是要确定查询的数据来自哪个表。如果 from 关键字后跟的表有两个或以上,就产生笛卡尔积。 2. where 子句对每个记录行进行 筛选,把不符合条件的行筛选掉。 3. 针对符合条件的行执行相应的表达式操作,即 select 部分。 我们针对前面的写的 SQL 语句简单模拟一下执行过程: 1. 确定数据表,我们能根据 from 子句( From student )确定数据是来自下面的的表 student ID Name Age 1 Tom 23 2 Jack 25 3 Lucy 15 4 Anay 18 5 Bobby 21 表 1 2. 根据 where 子句中的条件( Where age>20 )筛选 记录行,请留意, where 子句的 筛选是对每一行 from 表中的每一行进行的。 (1) 对于第 1 行 1 Tom 23 Age=23>20, 符合条件 (2) 对于第 2 行 2 Jack 25 Age=25>20, 符合条件 (3) 对于第 3 行 3 Lucy 15 Age=15<20, 不符合条件 (4) 对于第 4 行 4 Anay 18 Age=18<20, 不符合条件 (5)   |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |
你可能对下面的文章感兴趣
上一篇: SQL Server 2008在商务智能上的三个优化下一篇: 经典SQL语句大全
关于编写SQL查询的关键—SQL语句的执行顺序的所有评论