【Leetcode】高频SQL基础题--1341.电影评分
要求:请你编写一个解决方案:
查找评论电影数量最多的用户名。如果出现平局,返回字典序较小的用户名。
查找在 February 2020 平均评分最高 的电影名称。如果出现平局,返回字典序较小的电影名称。
字典序 ,即按字母在字典中出现顺序对字符串排序,字典序较小则意味着排序靠前。
返回结果格式如下例所示。
解题思路:
1、查找评论次数最多的用户(如果次数相同,则按用户名字典序取第一个)。
• 通过 INNER JOIN 内连接 将MovieRating表与Users表关联,确保只统计有评分记录的用户。使用GROUP BY MovieRating.user_id按用户ID分组,为后续聚合计算每个用户的评论总数做准备。
• ORDER BY COUNT(MovieRating.user_id) DESC: 按评论次数降序排列,找到最活跃的用户。
• ORDER BY ... Users.name ASC: 第二排序条件 ---当多个用户的评论次数相同时,按用户名升序排列,确保结果 deterministic(确定唯一用户)。
• LIMIT 1: 只取排名第一的用户。
2、查找2020年2月平均评分最高的电影(如果平均分相同,则按电影名字典序取第一个)。
• 通过 INNER JOIN 内连接 将MovieRating表与Movies表关联,确保只处理有评分记录的电影。WHERE子句筛选出2020年2月1日至2020年2月29日之间的评分记录(注意条件是< '2020-03-01',这是精准获取2月全月数据的推荐写法)。
• 使用GROUP BY MovieRating.movie_id按电影ID分组,计算每部电影的平均评分(AVG(MovieRating.rating))。
• ORDER BY AVG(MovieRating.rating) DESC: 按平均评分降序排列,找到评分最高的电影。
• ORDER BY ... Movies.title ASC: 第二排序条件 ---当多部电影平均评分相同时,按电影名升序排列,确保结果 deterministic(确定唯一电影)。
• LIMIT 1: 只取排名第一的电影。
3、最终用 UNION ALL将两个结果合并输出。
注意:
1、UNION、UNION ALL的语法
sql
(
... -- 第一个子查询
)
UNION ALL
(
... -- 第二个子查询
)
2、次要排序条件很重要!
3、下面这个时间判断是有问题的,是闭区间,会包含2020-3-1
sql
MovieRating.created_at between '2020-02-01' and DATE_ADD('2020-02-01', INTERVAL 1 Month)
代码:
sql
(
select Users.name as results
FROM MovieRating
JOIN Users
ON MovieRating.user_id = Users.user_id
GROUP BY MovieRating.user_id
ORDER BY
count(MovieRating.user_id) desc,
Users.name
LIMIT 1
)
UNION ALL
(
select Movies.title as results
FROM MovieRating
JOIN Movies ON MovieRating.movie_id = Movies.movie_id
WHERE
MovieRating.created_at >= '2020-02-01'
AND MovieRating.created_at < '2020-03-01'
GROUP BY MovieRating.movie_id
ORDER BY
avg(MovieRating.rating) desc,
Movies.title
LIMIT 1
)