2025年--Lc182--sql(排序和分组)--Java版

1.查询 至少有 5 个学生 的所有班级。

以 任意顺序 返回结果表。

结果格式如下所示。

输入

sql 复制代码
Courses table:
+---------+----------+
| student | class    |
+---------+----------+
| A       | Math     |
| B       | English  |
| C       | Math     |
| D       | Biology  |
| E       | Math     |
| F       | Computer |
| G       | Math     |
| H       | Math     |
| I       | Math     |
+---------+----------+

输出

sql 复制代码
+---------+ 
| class   | 
+---------+ 
| Math    | 
+---------+

解释:

-数学课有 6 个学生,所以我们包括它。

-英语课有 1 名学生,所以我们不包括它。

-生物课有 1 名学生,所以我们不包括它。

-计算机课有 1 个学生,所以我们不包括它。

sql 复制代码
select class
from Courses
group by class
having count(student)>=5

2.编写解决方案,对于每一个用户,返回该用户的关注者数量。

按 user_id 的顺序返回结果表。

查询结果的格式如下示例所示。

sql 复制代码
示例 1:

输入:
Followers 表:
+---------+-------------+
| user_id | follower_id |
+---------+-------------+
| 0       | 1           |
| 1       | 0           |
| 2       | 0           |
| 2       | 1           |
+---------+-------------+
输出:
+---------+----------------+
| user_id | followers_count|
+---------+----------------+
| 0       | 1              |
| 1       | 1              |
| 2       | 2              |
+---------+----------------+
解释:
0 的关注者有 {1}
1 的关注者有 {0}
复制代码
首先按照user_id进行分组,然后统计每一组的user_id数量即为关注的人数,并且各组之间按照user_id进行升序排序。
sql 复制代码
select user_id ,count(user_id) as followers_count
from Followers
group by user_id
order by user_id

3.单一数字 是在 MyNumbers 表中只出现一次的数字。

找出最大的 单一数字 。如果不存在 单一数字 ,则返回 null 。

查询结果如下例所示。

sql 复制代码
示例 1:

输入:
MyNumbers 表:
+-----+
| num |
+-----+
| 8   |
| 8   |
| 3   |
| 3   |
| 1   |
| 4   |
| 5   |
| 6   |
+-----+
输出:
+-----+
| num |
+-----+
| 6   |
+-----+
解释:单一数字有 1、4、5 和 6 。
6 是最大的单一数字,返回 6 。
sql 复制代码
示例 2:

输入:
MyNumbers table:
+-----+
| num |
+-----+
| 8   |
| 8   |
| 7   |
| 7   |
| 3   |
| 3   |
| 3   |
+-----+
输出:
+------+
| num  |
+------+
| null |
+------+
解释:输入的表中不存在单一数字,所以返回 null 。
 

使用子查询找出仅出现一次的数字。

java 复制代码
select num
from MyNumbers
group by num
having count(num)=1

然后使用 MAX() 函数找出其中最大的一个。

sql 复制代码
select max(num) as num
from
(select num
from MyNumbers
group by num
having count(num)=1 
) as t;
相关推荐
lvbinemail8 分钟前
Grafana模板自动复制图表
数据库·mysql·zabbix·grafana·监控
Miss_Chenzr15 分钟前
Springboot旅游景区管理系统9fu3n(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·旅游
小虾米vivian25 分钟前
dmetl5 运行失败,提示违反协议?
数据库·达梦数据库
C1829818257527 分钟前
HttpURLConnection 与其他客户端关系
java
weixin_4481199441 分钟前
Datawhale Hello-Agents入门篇202512第1次作业
数据库·sql·mysql
通往曙光的路上43 分钟前
发邮件1、创建邮箱
java
麦麦鸡腿堡1 小时前
Java_类的加载
java·开发语言
JIngJaneIL2 小时前
基于java + vue校园快递物流管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js
超级大只老咪2 小时前
数组的正向存储VS反向存储(Java)
java·开发语言·python