美文网首页
SQL-查询执行顺序

SQL-查询执行顺序

作者: 蕴重Liu | 来源:发表于2019-08-21 09:47 被阅读0次

当一个查询语句同时出现了where,group by,having,order by的时候,执行顺序和编写顺序。

count(列名)

使用count(列名)当某列出现null值的时候,count(*)仍然会计算,但是count(列名)不会

group by

select 列a,聚合函数(聚合函数规范) from 表明 where 过滤条件 group by 列a 
group by 字句也和where条件语句结合在一起使用。
当结合在一起时,where在前,group by 在后。
先对select xx from xx的记录集合用where进行筛选,然后再使用group by 对筛选后的结果进行分组。

having

对分组后的结果进行筛选,语法和where差不多
1.having只能用在group by之后,对分组后的结果进行筛选(即使用having的前提条件是分组)。
2.where肯定在group by 之前,即也在having之前。
3.where后的条件表达式里不允许使用聚合函数(count(),sum(),avg(),max(),min()),而having可以。

执行顺序和编写顺序

当一个查询语句同时出现了where,group by,having,order by的时候

1.执行where xx对全表数据做筛选,返回第1个结果集。
2.针对第1个结果集使用group by分组,返回第2个结果集。
3.针对第2个结果集中的每1组数据执行select xx,有几组就执行几次,返回第3个结果集。
4.针对第3个结集执行having xx进行筛选,返回第4个结果集。
5.针对第4个结果集排序。
from --> where --[result 1]--> group by --[result 2]--> select (x N) --[result 3]
--> having --[result 4]--> order by --> OUTPUT

完成一个复杂的查询语句,需求如下:
按由高到低的顺序显示个人平均分在70分以上的学生姓名和平均分,
为了尽可能地提高平均分,在计算平均分前不包括分数在60分以下的成绩,并且也不计算贱人(jr)的成绩。
1.要求显示学生姓名和平均分 因此确定第1步select s_name,avg(score) from student
2.计算平均分前不包括分数在60分以下的成绩,并且也不计算贱人(jr)的成绩 因此确定第2步 where score>=60 and s_name!=’jr’
3.显示个人平均分 相同名字的学生(同一个学生)考了多门科目 因此按姓名分组 确定第3步 group by s_name
4.显示个人平均分在70分以上 因此确定第4步 having avg(s_score)>=70
5.按由高到低的顺序 因此确定第5步 order by avg(s_score) desc

相关文章

  • SQL-查询执行顺序

    当一个查询语句同时出现了where,group by,having,order by的时候,执行顺序和编写顺序。 ...

  • 一、数据库之SQL语句

    一、SQL创表 二、SQL-插入 三、SQL-修改 四、SQL-删除 五、SQL-查询 以上是SQL语句常用的用法...

  • sql

    sql-基础sql-基础查询-1sql-基础查询-2sql-更新 概览 数据库(Database,DB):将大量数...

  • MySQL学习笔记- SQL 查询都是以 SELECT 开始的吗

    SQL 查询都是以 SELECT 开始的的吗?SQL 查询的执行顺序是怎样的? SQL 查询的执行顺序 SELEC...

  • Mysql进阶知识笔记

    一、SQL执行顺序以及常见SQL的join查询 sql执行顺序: 手写 机读顺序 sql机器执行顺序sql机器执行...

  • 程序员看了都要收藏系列:Mysql进阶知识干货笔记!

    一、SQL执行顺序以及常见SQL的join查询 sql执行顺序: 手写 机读顺序 sql机器执行顺序 七种join...

  • 查询语句执行顺序

    FORM: 对FROM的左边的表和右边的表计算笛卡尔积。产生虚表VT1 ON: 对虚表VT1进行ON筛选,只有那些...

  • SQL里的IN和EXISTS

    IN和EXISTS执行顺序不一样。 IN先执行后面的子查询,再执行外部查询,而EXISTS先执行前面的外部查询,再...

  • SQL执行顺序

    查询语句中select from where group by having order by的执行顺序 1.查询...

  • mysql-纪录级别操作

    增加记录 修改表记录 删除表记录 查询表记录 执行顺序 Mysql在执行sql语句时的执行顺序:from wher...

网友评论

      本文标题:SQL-查询执行顺序

      本文链接:https://www.haomeiwen.com/subject/scavsctx.html