【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
)
相关推荐
踩坑记录14 小时前
leetcode hot100 11.盛最多水的容器 medium 双指针
算法·leetcode·职场和发展
圣保罗的大教堂14 小时前
leetcode 865. 具有所有最深节点的最小子树 中等
leetcode
黑白极客14 小时前
怎么给字符串字段加索引?日志系统 一条更新语句是怎么执行的
java·数据库·sql·mysql·引擎
爬山算法15 小时前
Hibernate(31)Hibernate的原生SQL查询是什么?
数据库·sql·hibernate
X在敲AI代码15 小时前
LeetCode 基础刷题D2
算法·leetcode·职场和发展
源代码•宸15 小时前
Leetcode—1929. 数组串联&&Q1. 数组串联【简单】
经验分享·后端·算法·leetcode·go
weixin_4617694015 小时前
15. 三数之和
c++·算法·leetcode·三数之和
l1t16 小时前
NineData第三届数据库编程大赛:用一条 SQL 解数独问题我的参赛程序
数据库·人工智能·sql·算法·postgresql·oracle·数独
千金裘换酒16 小时前
LeetCode 链表两数相加
算法·leetcode·链表
施嘉伟17 小时前
一次生产环境 SQL 不走索引的排查过程
数据库·sql