MYSQL练题笔记-子查询-电影评分

一、题目相关内容

1)相关的表

2)题目

3)帮助理解题目的示例,提供返回结果的格式

二、自己初步的理解

1.字典序是指从前到后比较两个字符串大小的方法。 首先比较第1个字符,如果不同则第1个字符较小的字符串更小,一直这样子比较下去。 比如:s1:ABCDE 和 s2:ABCCE 两个字符串,s1的 D 比 s2的 C要更加大一点,所以s1 > s2。

然后百度到这些的时候我还以为要用到字符串比较的数据。

2.(movie_id, user_id)是唯一值那就是说一个用户只能评论一个电影一次呗,感觉要是是真实情况这样应该是不行的。

3.我思考是认为先解决第一个问题,评论电影数量最多的用户名,但是如果相等,就返回字典序较小的用户名;主要是我对这个部分完全想不到怎么写,所以我还是打算看题解了,我丢居然只需要order by,根本不需要max(),是我该学习啊。

三、题解展示和分析

题解如下,这样分组看比较有可读性。

# 评论电影数量最多且字典序较小的用户名

SELECT sub.name AS results
FROM( SELECT u.name
FROM Users u
JOIN MovieRating mr ON u.user_id = mr.user_id
GROUP BY 1
ORDER BY COUNT(*) DESC, 1
LIMIT 1) sub

UNION ALL
# 2020年2月份平均评分最高且字典序较小的电影名
(SELECT title
FROM Movies m
JOIN MovieRating mr ON m.movie_id = mr.movie_id AND created_at BETWEEN '2020-02-01' AND '2020-02-29'
GROUP BY 1
ORDER BY AVG(rating) DESC, 1
LIMIT 1)

1.既然是用union就先解决第一个问题-评论电影数量最多且字典序较小的用户名

1)这里利用子查询,没有直接查询name,可能是考虑了union里面不能order by 但是子句里可以,但是union all后面的查询语句不在子句里啊,我也不知道为啥能成功,在此留个疑问吧。

2)然后利用自连接把用户名和用户评分表连接起来。

3)然后group by 1就是根据第一列分组,也就是user_id这一列,如果自连接的时候user表放后面就不能这样使用了。

4)Order by 1指的是按select的第一个字段排序,通过order by 进行排序,根据count(*)降序即可,根本不用利用max()。

5)然后利用limit 输出第一条记录即可。

2.然后要使用union all因为有可能电影名和用户名是相同的,所以使用union的时候要思考和判断一下是否要加all

3.解决第二个问题-2020年2月份平均评分最高且字典序较小的电影名

其实这个总的结构和解决第一个问题是差不多的,只是多了个where条件限制在2020年2月份,然后要想到可以利用avg()进行排序,那这个问题就解决了。

四、总结

1.字典序是指从前到后比较两个字符串大小的方法;

2.日期范围可以利用between and或者<= 和>;

3.只需要输出某个值最大的时候可以用排序加上limit 1。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/267803.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux(5):linux基础命令第五弹

在linux基础命令第四弹中http://t.csdnimg.cn/tvuNl我们了解了echo、tail命令、管道符和vim文本编辑器的相关内容。这一篇我们会了解关于命令选项的说明 我们在之前的学习中&#xff0c;发现命令中的选项是非常多的&#xff0c;比如-l -c -m -r -w 等等&#xff0c;命令有很多&…

12月11日作业

完善对话框&#xff0c;点击登录对话框&#xff0c;如果账号和密码匹配&#xff0c;则弹出信息对话框&#xff0c;给出提示登录成功&#xff0c;提供一个Ok按钮&#xff0c;用户点击Ok后&#xff0c;关闭登录界面&#xff0c;跳转到其他界面 如果账号和密码不匹配&#xff0c;弹…

Python3 中常见的数据类型

目录 数字(Number)总结 字符串(String)字符串运算符字符串格式化字符串的截取总结 List&#xff08;列表&#xff09;更新列表删除列表元素列表函数&方法总结 Tuple&#xff08;元组&#xff09;修改元组删除元组总结 Set&#xff08;集合&#xff09;Dictionary&#xff0…

Anaconda安装-超详细版(2023)

Anaconda安装 - 超详细版&#xff08;2023&#xff09; 前言&#xff1a;彻底卸载pythonAnaconda下载地址安装详细步骤配置环境变量检验安装是否成功更改conda源&#xff08;后续安装第三方库可以加快速度&#xff09;超详细彻底卸载Anaconda教程Tensorflow-gpu 安装 前言&…

基于FPGA的视频接口之高速IO(光纤)

简介 对于高速IO口配置光纤&#xff0c;现在目前大部分开发板都有配置&#xff0c;且也有说明&#xff0c;在此根据自己的工作经验以及对于各开发板的说明归纳 通过高速IO接口&#xff0c;以及硬件配置&#xff0c;可以实现对于光纤的收发功能&#xff0c;由于GTX的速率在500Mb…

【NR技术】NR NG-RAN整体架构 -网络接口以及无线协议框架(四)

1 引言 本博文介绍NR NG-RAN的网络节点间的接口以及无线协议框架。网络接口介绍包括RAN和NGC之间的NG接口&#xff1b;无线协议框架包括用户面和控制面协议。 2 NG接口 2.1 NG用户面接口 NG-U (user plane interface)是NG-RAN节点与UPF之间的接口。NG接口的用户平面协议栈如图…

算法Day28 二进制差异序列(格雷码)

二进制差异序列&#xff08;格雷码&#xff09; Description n 位二进制差异序列是一个由2^n个整数组成的序列&#xff0c;其中&#xff1a; 每个整数都在范围[0, 2^n - 1]内&#xff08;含0和2^n - 1&#xff09; 第一个整数是0 一个整数在序列中出现不超过一次 每对相邻整数…

sdxl-turbo:adversarial diffusion distillation

【AIGC第三十一篇】SDXL Turbo&#xff1a;一种实时的文本到图像生成模型 - 知乎【 SDXL Turbo通过采用全新的蒸馏技术&#xff0c;实现了最先进的性能&#xff0c;能够以前所未有的质量进行单步图像生成&#xff0c;将所需的步骤数量从50步减少到仅需一步。这种创新技术大大提…

cache教程 2.单机并发缓存

0.对原教程的一些见解 个人认为原教程中两点知识的引入不够友好。 首先是只读数据结构 ByteView 的引入使用是有点迷茫的&#xff0c;可能不能很好理解为什么需要ByteView。 第二是主体结构 Group的引入也疑惑。其实要是熟悉groupcache&#xff0c;那对结构Group的使用是清晰…

最大公因数,最小公倍数详解

前言 对于初学编程的小伙伴们肯定经常遇见此类问题&#xff0c;而且为之头疼&#xff0c;今天我来给大家分享一下&#xff0c;最大公因数和最小公倍数的求法。让我们开始吧&#xff01; 文章目录 1&#xff0c;最大公因数法1法2法3 2&#xff0c;最小公倍数3&#xff0c;尾声 …

UE引擎 LandscapeGrass 实现机制分析(UE5.2)

前言 随着电脑和手机硬件性能越来越高&#xff0c;游戏越来越追求大世界&#xff0c;而大世界非常核心的一环是植被&#xff0c;目前UE5引擎提供给植被生成的主流两种方式为 手刷植被和LandscapeGrass(WeightMap程序化植被)。当然UE5.3推出新一代PCGFramework 节点程序化生成框…

Nvdiffrast高性能可微渲染开发包

NSDT工具推荐&#xff1a; Three.js AI纹理开发包 - YOLO合成数据生成器 - GLTF/GLB在线编辑 - 3D模型格式在线转换 - 可编程3D场景编辑器 - REVIT导出3D模型插件 - 3D模型语义搜索引擎 Nvdiffrast 是一个 PyTorch/TensorFlow 库&#xff0c;为基于光栅化的可微渲染提供高性能基…