扫码订阅《 》或入驻星球,即可阅读文章!

GOLANG ROADMAP

阅读模式

  • 沉浸
  • 自动
  • 日常
首页
Go学习
  • Go学院

    • Go小课
    • Go视界
    • Go小考
    • Go实战
  • Go资源

    • 优质课程
    • 在线宝典
    • 资源下载
    • 帮找资源
训练营 🔥
  • Go体系课&实战训练营
  • 升值加薪陪跑训练营
Go求职
  • 求职刷题

    • 企业题库
    • 面试宝典
    • 求职面经
  • 求职服务

    • 内推互助
    • 求职助力
    • 内推公司
Go友会
  • 城市
  • 校园
推广返佣
  • 返佣排行
  • 返佣规则
  • 推广学院
实验区
  • Go周边
  • Go宝典

    • 推荐图书
    • 精品博文
  • Go开源

    • Go仓库
    • Go月刊
更多
  • 用户中心

    • 我的信息
    • 我的返佣
    • 我的消息
  • 玩转星球

    • 星球介绍
    • 星主权益
    • 吐槽专区
    • 成长记录
  • 合作交流

    • 商务合作
    • 讲师招募
    • 生态伙伴
author-avatar

GOLANG ROADMAP


首页
Go学习
  • Go学院

    • Go小课
    • Go视界
    • Go小考
    • Go实战
  • Go资源

    • 优质课程
    • 在线宝典
    • 资源下载
    • 帮找资源
训练营 🔥
  • Go体系课&实战训练营
  • 升值加薪陪跑训练营
Go求职
  • 求职刷题

    • 企业题库
    • 面试宝典
    • 求职面经
  • 求职服务

    • 内推互助
    • 求职助力
    • 内推公司
Go友会
  • 城市
  • 校园
推广返佣
  • 返佣排行
  • 返佣规则
  • 推广学院
实验区
  • Go周边
  • Go宝典

    • 推荐图书
    • 精品博文
  • Go开源

    • Go仓库
    • Go月刊
更多
  • 用户中心

    • 我的信息
    • 我的返佣
    • 我的消息
  • 玩转星球

    • 星球介绍
    • 星主权益
    • 吐槽专区
    • 成长记录
  • 合作交流

    • 商务合作
    • 讲师招募
    • 生态伙伴
  • 数据库系列

    • SQL 语法
  • 核心语法

    • 一、基础
    • 二、创建表
    • 三、修改表
    • 四、插入
    • 五、更新
    • 六、删除
    • 七、查询
    • 八、排序
    • 九、过滤
    • 十、通配符
    • 十一、计算字段
    • 十二、函数
    • 十三、分组
    • 十四、子查询
    • 十五、连接
    • 十六、组合查询
    • 十七、视图
    • 十八、存储过程
    • 十九、游标
    • 二十、触发器
    • 二十一、事务管理
    • 二十二、字符集
    • 二十三、权限管理
  • SQL练习

    • 595. Big Countries
    • 627. Swap Salary
    • 620. Not Boring Movies
    • 596. Classes More Than 5 Students
    • 182. Duplicate Emails
    • 196. Delete Duplicate Emails
    • 175. Combine Two Tables
    • 181. Employees Earning More Than Their Managers
    • 183. Customers Who Never Order
    • 184. Department Highest Salary
    • 176. Second Highest Salary
    • 177. Nth Highest Salary
    • 178. Rank Scores
    • 180. Consecutive Numbers
    • 626. Exchange Seats

扫码订阅《 》或入驻星球,即可阅读文章!

596. Classes More Than 5 Students


GOLANG ROADMAP

# Description

+---------+------------+
| student | class      |
+---------+------------+
| A       | Math       |
| B       | English    |
| C       | Math       |
| D       | Biology    |
| E       | Math       |
| F       | Computer   |
| G       | Math       |
| H       | Math       |
| I       | Math       |
+---------+------------+
1
2
3
4
5
6
7
8
9
10
11
12
13

查找有五名及以上 student 的 class。

+---------+
| class   |
+---------+
| Math    |
+---------+
1
2
3
4
5

# Solution

对 class 列进行分组之后,再使用 count 汇总函数统计每个分组的记录个数,之后使用 HAVING 进行筛选。HAVING 针对分组进行筛选,而 WHERE 针对每个记录(行)进行筛选。

SELECT
    class
FROM
    courses
GROUP BY
    class
HAVING
    count( DISTINCT student ) >= 5;
1
2
3
4
5
6
7
8

# SQL Schema

DROP TABLE
IF
    EXISTS courses;
CREATE TABLE courses ( student VARCHAR ( 255 ), class VARCHAR ( 255 ) );
INSERT INTO courses ( student, class )
VALUES
    ( 'A', 'Math' ),
    ( 'B', 'English' ),
    ( 'C', 'Math' ),
    ( 'D', 'Biology' ),
    ( 'E', 'Math' ),
    ( 'F', 'Computer' ),
    ( 'G', 'Math' ),
    ( 'H', 'Math' ),
    ( 'I', 'Math' );
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
  • Description
  • Solution
  • SQL Schema