【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
)
相关推荐
夏乌_Wx8 小时前
练题100天——DAY23:存在重复元素Ⅰ Ⅱ+两数之和
数据结构·算法·leetcode
Knight_AL11 小时前
MySQL STORED 生成列(Generated Column)详解:让 SQL 变快的秘密武器
数据库·sql·mysql
Dragon online12 小时前
数据分析师成长之路--从SQL恐惧到数据掌控者的蜕变
数据库·sql
ada7_14 小时前
LeetCode(python)108.将有序数组转换为二叉搜索树
数据结构·python·算法·leetcode
Li.CQ14 小时前
SQL学习笔记
笔记·sql·学习
独自破碎E14 小时前
加油站环路问题
java·开发语言·算法·leetcode
Swift社区15 小时前
LeetCode 445 - 两数相加 II
算法·leetcode·职场和发展
墨染点香15 小时前
LeetCode 刷题【187. 重复的DNA序列】
算法·leetcode·职场和发展
Navicat中国15 小时前
Navicat 技术指引 | 面向达梦的查询工具
数据库·sql·达梦·navicat·查询