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

2022-05-27 08:20:25 浏览数 (2)

目录

  • 1 编写顺序

1 编写顺序

当一个查询语句同时出现了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个结果集排序。

Group By 和 Having, Where ,Order by这些关键字是按照如下顺序进行执行的:Where, Group By, Having, Order by。

代码语言:javascript复制
-- 3、查询平均成绩大于等于60分的同学的学生编号和学生姓名和平均成绩
 
select b.s_id,b.s_name,ROUND(AVG(a.s_score),2) as avg_score from 
	student b 
	join score a on b.s_id = a.s_id
	GROUP BY b.s_id,b.s_name HAVING avg_score >=60;

根据题意,需要用到信息表 成绩表

首先查出有成绩的学生,也就是两个表联查

代码语言:javascript复制
select b.s_id,b.s_name,ROUND(AVG(a.s_score),2) as avg_score from 
	student b 
	join score a on b.s_id = a.s_id

0 人点赞