【Leetcode】高频SQL基础题--1341.电影评分

【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
)
相关推荐
踩坑记录16 小时前
leetcode hot100 94. 二叉树的中序遍历 easy 递归 dfs
leetcode
醉颜凉18 小时前
【LeetCode】打家劫舍III
c语言·算法·leetcode·树 深度优先搜索·动态规划 二叉树
达文汐18 小时前
【困难】力扣算法题解析LeetCode332:重新安排行程
java·数据结构·经验分享·算法·leetcode·力扣
一匹电信狗18 小时前
【LeetCode_21】合并两个有序链表
c语言·开发语言·数据结构·c++·算法·leetcode·stl
User_芊芊君子18 小时前
【LeetCode经典题解】搞定二叉树最近公共祖先:递归法+栈存路径法,附代码实现
算法·leetcode·职场和发展
培风图南以星河揽胜18 小时前
Java版LeetCode热题100之零钱兑换:动态规划经典问题深度解析
java·leetcode·动态规划
算法_小学生18 小时前
LeetCode 热题 100(分享最简单易懂的Python代码!)
python·算法·leetcode
执着25918 小时前
力扣hot100 - 234、回文链表
算法·leetcode·链表
熬夜造bug18 小时前
LeetCode Hot100 刷题路线(Python版)
算法·leetcode·职场和发展
我真的是大笨蛋19 小时前
深度解析InnoDB如何保障Buffer与磁盘数据一致性
java·数据库·sql·mysql·性能优化