Sql语句实现某列每条记录与同列最大值的差值计算

本文通过一个具体的案例,深入解析了SQL查询的执行流程及关键步骤,包括FROM和JOIN、WHERE筛选、GROUP BY分组、HAVING筛选、SELECT计算、DISTINCT去重、ORDER BY排序及LIMIT截取等,帮助读者掌握复杂SQL查询的设计与优化。
摘要由CSDN通过智能技术生成

题目:找出每部电影和单部电影销售冠军之间的销售差,列出电影名,销售额差额

表结构:

结果:

SQL语句:

select title, ABS(total_sales - (select total_sales from (select m.*, b.*, sum(b.Domestic_sales + b.International_sales) as total_sales 
from movies m left join Boxoffice b on m.id = b.movie_id
group by m.id
order by total_sales desc limit 1))) as diff from
(select m.*, b.*, sum(b.Domestic_sales + b.International_sales) as total_sales 
from movies m
left join Boxoffice b on m.id = b.movie_id
group by m.id
order by total_sales desc);

 关键学习点:掌握sql查询执行过程

1. FROM 和 JOINs

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

2. WHERE

我们确定了数据来源 WHERE 语句就将在这个数据源中按要求进行数据筛选,并丢弃不符合要求的数据行,所有的筛选col属性 只能来自FROM圈定的表. AS别名还不能在这个阶段使用,因为可能别名是一个还没执行的表达式

3. GROUP BY

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

4. HAVING

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

5. SELECT

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

6. DISTINCT

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

7. ORDER BY

在结果集确定的情况下,ORDER BY 对结果做排序。因为SELECT中的表达式已经执行完了。此时可以用AS别名.

8. LIMIT / OFFSET

最后 LIMIT 和 OFFSET 从排序的结果中截取部分数据.

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值