SQL学习(六)查询执行顺序

至此,SELECT查询的基础学完了,这一节的练习题有一些很不容易写出来,只能先这样,之后温故知识,多练习,慢慢熟悉。

基础语法

一个完整的的SELECT查询

SELECT DISTINCT column, AGG_FUNC(column_or_expression), …
FROM mytable
    JOIN another_table
      ON mytable.column = another_table.column
    WHERE constraint_expression
    GROUP BY column
    HAVING constraint_expression
    ORDER BY column ASC/DESC
    LIMIT count OFFSET COUNT;
  1. FROM 和 JOIN

我们确定了数据来源

FROMJOIN会第一个执行,确定一个整体的数据范围. 如果要JOIN不同表,可能会生成一个临时Table来用于 下面的过程。总之第一步可以简单理解为确定一个数据源表(含临时表)。

  1. WHERE

按要求进行数据筛选,丢弃不符合要求的数据行。

  1. GROUP BY

GROUP BY 将对之前的数据进行分组,统计等,并将是结果集缩小为分组数.这意味着 其他的数据在分组后丢弃.

  1. HAVING

如果你用了 GROUP BY 分组, HAVING 会在分组完成后对结果集再次筛选。AS别名也不能在这个阶段使用.

  1. SELECT

确定结果之后,SELECT用来对结果col简单筛选或计算,决定输出什么数据.

  1. DISTINCT

如果数据行有重复DISTINCT 将负责排重.

  1. ORDER BY

排序

  1. LIMIT / OFFSET

截取

练习

练习题出自自学SQL

  1. 统计出每一个导演的电影数量(列出导演名字和数量)
SELECT director,COUNT(director) FROM movies
GROUP by director;

查询所有的director数据,并新增一列熟练。GROUP by对director进行分组。

下面这些初学就不是很容易写出来了,参考答案理解语句

  1. 统计一下每个导演的销售总额(列出导演名字和销售总额)
SELECT director,SUM(Domestic_sales+International_sales)as sales FROM movies
LEFT JOIN Boxoffice 
ON movies.Id=Boxoffice.Movie_id
GROUP BY director;
  1. 按导演分组计算销售总额,求出平均销售额冠军(统计结果过滤掉只有单部电影的导演,列出导演名,总销量,电影数量,平均销量)
SELECT director,sum(Domestic_sales+International_sales)as sales,COUNT(director),
SUM(Domestic_sales+International_sales)/COUNT(director) as avgsales FROM movies
LEFT JOIN Boxoffice 
ON movies.Id=Boxoffice.Movie_id
GROUP BY director
HAVING Count(Director)>1
ORDER BY Avgsales DESC
LIMIT 1
  1. 找出每部电影和单部电影销售冠军之间的销售差,列出电影名,销售额差额
SELECT title ,(SELECT max(international_sales+domestic_sales) FROM boxoffice)-(international_sales+domestic_sales) FROM movies 
LEFT JOIN boxoffice ON movies.id=boxoffice.movie_id
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Morris_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值