【大数据系列之MySQL】(二十七):子查询的经典使用案例

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云原生大数据计算服务MaxCompute,500CU*H 100GB 3个月
简介: 【大数据系列之MySQL】(二十七):子查询的经典使用案例
+关注继续查看

案例1:查询工资最低的员工信息:last_name,salary(where后标量子查询

首先查询出最低工资,然后使用该工资进行筛选

SELECT last_name, salary FROM employees WHERE salary =( SELECT min( salary ) FROM employees );

案例2:查询平均工资最低的部门信息(from后表子查询,where后标量子查询)

先查询出部门的平均工资,然后在查哪个部门的平均工资最低,再查哪个部门的平均工资等于最低工资,最后查询部门信息

SELECT
    * 
FROM
    departments 
WHERE
    department_id =(
    SELECT
        department_id 
    FROM
        ( SELECT department_id, avg( salary ) avg FROM employees GROUP BY department_id ) ad 
    WHERE
        avg =(
        SELECT
            min( avg ) 
        FROM
        ( SELECT department_id, avg( salary ) avg FROM employees GROUP BY department_id ) ad 
    ));

案例3:查询平均工资最低的部门信息和该部门的平均工资

SELECT
    * 
FROM
    (
    SELECT
        * 
    FROM
        departments 
    WHERE
        department_id =(
        SELECT
            department_id 
        FROM
            ( SELECT department_id, avg( salary ) avg FROM employees GROUP BY department_id ) ad 
        WHERE
            avg =(
            SELECT
                min( avg ) 
            FROM
                ( SELECT department_id, avg( salary ) avg FROM employees GROUP BY department_id ) ad 
            ))) a
    JOIN ( SELECT department_id, avg( salary ) avg FROM employees GROUP BY department_id ) b ON a.department_id = b.department_id;

案例4:查询平均工资最高的job信息

先查询出平均工资最高的job_id是什么,然后再去job表中查询

SELECT
    * 
FROM
    jobs 
WHERE
    job_id = (
    SELECT
        job_id 
    FROM
        employees 
    GROUP BY
        job_id 
    ORDER BY
    avg( salary ) DESC 
    LIMIT 1)

案例5:查询平均工资高于公司平均工资的部门有哪些?

首先查询出公司的平均工资,然后再查询出各部门的平均工资,然后使用having进行筛选

SELECT
    department_id,
    avg( salary ) ag 
FROM
    employees 
GROUP BY
    department_id 
HAVING
    ag >(
    SELECT
        avg( salary ) ag 
    FROM
    employees)

案例6:查询出公司中所有manager的详细信息

首先查询出公司中所有的manager的id,然后使用in去做遍历

SELECT
    * 
FROM
    employees 
WHERE
    employee_id IN (
    SELECT DISTINCT
        manager_id 
    FROM
        employees 
WHERE
    manager_id IS NOT NULL)

案例7:各个部门中最高工资中最低的那个部门的最低工资是多少

SELECT
    min( salary ) 
FROM
    employees 
WHERE
    department_id = ( SELECT department_id FROM employees GROUP BY department_id ORDER BY max( salary ) LIMIT 1 );

案例8:查询平均工资最高的部门的manager的详细信息:last_name,department_id,email,salary

SELECT
    last_name,
    department_id,
    email,
    salary 
FROM
    employees 
WHERE
    employee_id IN ( SELECT DISTINCT manager_id FROM employees WHERE manager_id IS NOT NULL ) 
    AND department_id = ( SELECT department_id FROM employees GROUP BY department_id ORDER BY avg( salary ) DESC LIMIT 1 );


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
6天前
|
人工智能 监控 物联网
基于物联网、大数据、云计算、人工智能等技术的智慧工地源码(Java+Spring Cloud +UniApp +MySql)
基于物联网、大数据、云计算、人工智能等技术的智慧工地源码(Java+Spring Cloud +UniApp +MySql)
22 0
|
3月前
|
关系型数据库 MySQL 大数据
大数据Sqoop将mysql直接抽取至Hbase
大数据Sqoop将mysql直接抽取至Hbase
51 0
|
3月前
|
SQL 分布式计算 分布式数据库
大数据Sqoop借助Hive将Mysql数据导入至Hbase
大数据Sqoop借助Hive将Mysql数据导入至Hbase
39 0
|
6月前
|
SQL Oracle 关系型数据库
【大数据学习篇14】centos6安装Mysql(下)
【大数据学习篇14】centos6安装Mysql
38 0
|
6月前
|
SQL Oracle 关系型数据库
【大数据学习篇14】centos6安装Mysql(上)
【大数据学习篇14】centos6安装Mysql
104 0
|
6月前
|
存储 分布式计算 关系型数据库
大数据数据存储的数据库的关系型数据库之MySQL
在大数据领域,数据库是数据存储的一个重要组成部分。关系型数据库MySQL是其中的一种常见类型。本文将对MySQL进行介绍。
62 2
|
6月前
|
SQL 分布式计算 关系型数据库
大数据 | (五)通过Sqoop实现从MySQL导入数据到HDFS
大数据 | (五)通过Sqoop实现从MySQL导入数据到HDFS
|
11月前
|
Java 关系型数据库 MySQL
【大数据系列之JDBC】(二):IDEA添加MySQL驱动jar包
【大数据系列之JDBC】(二):IDEA添加MySQL驱动jar包
99 0
【大数据系列之JDBC】(二):IDEA添加MySQL驱动jar包
|
11月前
|
关系型数据库 MySQL Java
【大数据系列之MySQL】(三十五):MySQL中的流程控制
【大数据系列之MySQL】(三十五):MySQL中的流程控制
75 0
|
11月前
|
存储 SQL 关系型数据库
【大数据系列之MySQL】(三十四):存储过程的介绍
【大数据系列之MySQL】(三十四):存储过程的介绍
112 0
推荐文章
更多