【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
)
相关推荐
6Hzlia6 小时前
【Hot 100 刷题计划】 LeetCode 48. 旋转图像 | C++ 矩阵变换题解
c++·leetcode·矩阵
XDHCOM7 小时前
PostgreSQL 25001: active_sql_transaction 报错原因分析,故障修复步骤详解,远程处理解决方案
数据库·sql·postgresql
Morwit7 小时前
【力扣hot100】 1. 两数之和
数据结构·c++·算法·leetcode·职场和发展
py有趣8 小时前
力扣热门100题之岛屿的数量(DFS/BFS经典题)
leetcode·深度优先·宽度优先
qinian_ztc9 小时前
frida 14.2.18 安装报错解决
算法·leetcode·职场和发展
田梓燊10 小时前
2026/4/11 leetcode 3741
数据结构·算法·leetcode
祖传F8711 小时前
quickbi数据集数据查询时间字段显示正确,仪表板不显示
数据库·sql·阿里云
悟道子HD12 小时前
SRC漏洞挖掘——2.SQL注入漏洞实战详解
sql·web安全·网络安全·渗透测试·sql注入·sqlmap·暴力破解
小肝一下12 小时前
每日两道力扣,day8
c++·算法·leetcode·哈希算法·hot100
语戚14 小时前
力扣 51. N 皇后:基础回溯、布尔数组优化、位运算全解(Java 实现)
java·算法·leetcode·力扣·剪枝·回溯·位运算