例子文件1:https://files.cnblogs.com/files/Vera-y/myemployees.zip

子查询:又称内查询,出现在其他语句中的select语句

主查询:又称外查询,内部嵌套其他select语句的查询

分类:

按结果集的行列数不同:

  标量(单行)子查询:结果集只有一行一列

  列(多行)子查询:结果集只有一列多行

  行子查询:结果集有一行多列

  表子查询:结果集一般为多行多列(也可包含一行多列等)

按子查询出现的位置:

  select 后面:仅仅支持标量子查询

  from 后面:支持表子查询

  ♦ where或having后面:支持标量子查询、列子查询、(也可行子查询(使用较少))

  exists后面(又称相关子查询):表子查询

一、放在where或having后面

特点:1)子查询语句放在小括号内

   2)子查询语句一般放在条件的右侧

   3)标量子查询,一般配合这单行操作符使用(> < >= <= = <>)

      列子查询,一般搭配多行操作符使用(IN / NOT IN 、ANY / SOME 、ALL)

   4)子查询的执行优先于主查询的执行

非法使用标量子查询:

  1)子查询结果集不为一行一列

  2)子查询结果集为空

1.标量子查询

例1.谁的工资比Abel高?

SELECT last_name,salary
FROM employees
WHERE salary>(
SELECT salary
FROM employees
WHERE last_name='Abel'
);

例2.返回job_id与141号员工相同,salary比143员工多的员工 姓名,job_id和工资

SELECT salary,last_name,job_id
FROM employees
WHERE salary > (
SELECT salary
FROM employees
WHERE employee_id='143'
)AND job_id = (
SELECT job_id
FROM employees
WHERE employee_id='141'
);

例3.查询最低工资大于50号部门最低工资的部门id和其最低工资

SELECT department_id,MIN(salary)
FROM employees
GROUP BY department_id
HAVING MIN(salary) > (
SELECT MIN(salary)
FROM employees
WHERE department_id=50
);

2.列子查询(单列多行子查询)

例1.返回location_id 是1400或1700的部门中所有员工姓名

SELECT last_name
FROM employees
WHERE department_id IN(        # 这里的 IN 可以替换外 =ANY
SELECT DISTINCT department_id
FROM departments
WHERE location_id IN(1400,1700)
);

例2.返回其它工种中比job_id为 IT_PROG工种任一工资低的员工的员工号、姓名、job_id、salary

SELECT employee_id, last_name,job_id,salary
FROM employees
WHERE salary<ANY(
SELECT DISTINCT salary # 去重
FROM employees
WHERE job_id = 'IT_PROG'
)AND job_id <> 'IT_PROG';
# 或
SELECT employee_id, last_name,job_id,salary
FROM employees
WHERE salary<(
SELECT MAX(salary)
FROM employees
WHERE job_id = 'IT_PROG'
)AND job_id <> 'IT_PROG';

例3.返回其它工种中比job_id为 IT_PROG工种所有工资低的员工的员工号、姓名、job_id、salary

SELECT employee_id, last_name,job_id,salary
FROM employees
WHERE salary<ALL(
SELECT DISTINCT salary # 去重
FROM employees
WHERE job_id = 'IT_PROG'
)AND job_id <> 'IT_PROG';
#或
SELECT employee_id, last_name,job_id,salary
FROM employees
WHERE salary<(
SELECT MIN(salary) # 去重
FROM employees
WHERE job_id = 'IT_PROG'
)AND job_id <> 'IT_PROG';

3.行子查询(结果集一行多列或多行多列)

例:查询员工编号最小并且工资最高的员工信息

1)普通解法  

  SELECT *
  FROM employees
  WHERE employee_id =(
  SELECT MIN(employee_id)
  FROM employees
  )AND salary=(
  SELECT MAX(salary)
  FROM employees
  );

2)行子查询解法

  SELECT *
  FROM employees
  WHERE (employee_id,salary)=(
  SELECT MIN(employee_id),MAX(salary)
  FROM employees
  );

二、放在select后面

例1.查询每个部门的员工个数     # 部门表 、员工表

SELECT departments.*, (
  SELECT COUNT(*)
  FROM employees
  WHERE employees.department_id = departments.department_id
) AS 个数
FROM departments;

例2.查询员工号=102的部门名    # 可直接用连接查询、标量查询等

SELECT (                            # 只能是一行一列(标量子查询)
  SELECT department_name
  FROM departments
  INNER JOIN employees
  ON departments.department_id=employees.department_id
  WHERE employees.employee_id=102
) AS 部门名;

三、放在from后面

例、查询每个部门的平均工资的工资等级

SELECT ag_dep.*,grade_level
FROM(
  SELECT AVG(salary) AS ag,department_id
  FROM employees
  GROUP BY department_id
) AS ag_dep     # 子查询结果为一张表,注意一定要起别名
INNER JOIN job_grades
ON ag_dep.ag BETWEEN lowest_sal AND highest_sal;

四、放在exists后面(相关子查询)

语法:select.. exists(完整的子查询语句)

判断子查询的结果有没有值,若有值则返回布尔值1,没有则返回布尔值0

注:exists是先执行外查询,再进行子查询的过滤

例1.查询有员工的部门名

用exists进行相关查询

  SELECT department_name
  FROM departments
  WHERE EXISTS(
    SELECT *
    FROM employees
    WHERE departments.department_id=employees.department_id
  );

用IN 进行查询

  SELECT department_name
  FROM departments
  WHERE departments.department_id IN(
    SELECT department_id
    FROM employees
  );

数据库MySQL--子查询的更多相关文章

  1. [慢查优化]慎用MySQL子查询,尤其是看到DEPENDENT SUBQUERY标记时

    案例梳理时间:2013-9-25 写在前面的话: 在慢查优化1和2里都反复强调过 explain 的重要性,但有时候肉眼看不出 explain 结果如何指导优化,这时候还需要有一些其他基础知识的佐助, ...

  2. MySQL子查询,派生表和通用表达式

    一:子查询 1.介绍 在另一个查询(外部查询)中嵌套另一个查询语句(内部查询),并使用内部查询的结果值作为外部查询条件. 2.子查询在where中 SELECT customerNumber, che ...

  3. MySQL子查询有哪五种形式?

    MySQL是一个关系型数据库管理系统,由瑞典MySQLAB公司开发,目前属于Oracle旗下产品.MySQL是最流行的关系型数据库管理系统之一,在web应用方面,MySQL是最好的RDBMS(Rela ...

  4. Mysql子查询、关联查询

    mysql中update.delete.install尽量不要使用子查询 一.mysql查询的五种子句         where(条件查询).having(筛选).group by(分组).orde ...

  5. Mysql子查询IN中使用LIMIT

    学习下Mysql子查询IN中使用LIMIT的方法. 这两天项目里出了一个问题,mysql LIMIT使用后报错. 需求是这样的,我有3张表,infor信息表,mconfig物料配置表,maaply物料 ...

  6. MySQL 子查询 EXISTS 和 NOT EXISTS(转)

    MySQL EXISTS 和 NOT EXISTS 子查询 MySQL EXISTS 和 NOT EXISTS 子查询语法如下: SELECT ... FROM table WHERE EXISTS ...

  7. mysql子查询慢的问题

      当你在用explain工具查看sql语句的运行计划时.若select_type 字段中出现"DEPENDENT SUBQUERY"时,你要注意了.你已经掉入了mysql子查询慢 ...

  8. MySQL子查询慢现象的解决

    当你在用explain工具查看sql语句的执行计划时,若select_type 字段中出现“DEPENDENT SUBQUERY”时,你要注意了,你已经掉入了mysql子查询慢的“坑". 相 ...

  9. mysql子查询用法

    mysql子查询用法 1 可以当值来用<pre>select id from hcyuyin_share where id=(select id from hcyuyin_share li ...

  10. MySQL 子查询(一)

    源自MySQL 5.7 官方手册 13.2.10 Subquery Syntax 〇.MySQL子查询介绍 子查询指的是嵌套在某个语句中的SELECT语句. MySQL支持标准SQL所要求的所有子查询 ...

随机推荐

  1. 10 个轻松学会 CSS3 的优秀在线资源

    本文包揽 CSS 的所有关键点,并且引入了最新的 CSS3 版本.这个先进的技术提供超级多的新标签和属性,使得 Web 设计构建创新更简单,帮助开发者创建具有新趋势,带有漂亮布局的 Web 页面.随着 ...

  2. Spring Boot整合Thymeleaf模板引擎

    什么是Thymeleaf Thymeleaf是一款用于渲染XML.XHTML.HTML5内容的模板引擎.类似Velocity,FreeMaker模板引擎,它也可以轻易的与Spring MVC等Web框 ...

  3. Unity中对注册表进行修改

    问题背景: PC端软件开发,当我在Unity中的PlayerSetting中设置好分辨率,每次打包运行后会记忆上次退出时窗口的分辨率(记忆窗口状态),导致下次打开时不是PlayerSetting中的初 ...

  4. (Struts2学习系列四)Struts2指定配置文件

    我们的每个action都在struts.xml里配置的话,就会出现很多的xml语句,单单一个struts.xml就会变得很大,所以我们会在struts.xml里使用include引入其他的.xml文件 ...

  5. oracle密码过期,改为原来的密码

    我们都知道Oracle 数据库的用户的密码默认是有有效期限制的,特别是在Cloud上面的DB,有些用户是Cloud自动创建的,我们不知道原来的密码是什么,但是如果密码过期了,如果修改成新的密码,会影响 ...

  6. linux常用命令-4查看文件内容命令

    vi file #打开并浏览文件 grep str /tmp/test #在文件 ‘/tmp/test’ 中查找 “str” grep ^str /tmp/test #在文件 ‘/tmp/test’ ...

  7. 在VisualGDB中配置预编译头加快编译速度

    今天是中秋佳节,但是写完已经是第二天凌晨了,还是祝大家中秋快乐! VS对C++的支持相较GCC太弱了,连续几个VS版本对C++的改进都很小.很少.对Cpper也许是一种痛,我们也许希望能使用VS的强大 ...

  8. Java中volatile关键字及其作用是什么?

    在 Java 多线程中如何保证线程的安全性?那我们可以使用 Synchronized 同步锁来给需要多个线程访问的代码块加锁以保证线程安全性.使用 synchronized 虽然可以解决多线程安全问题 ...

  9. usb基础知识以及枚举过程介绍

    一个USB设备有一个设备描述符,设备描述符里面决定了该设备有多少种配置,每种配置描述符对应着配置描述符:而在配置描述符中又定义了该配置里面有多少个接口,每个接口有对应的接口描述符:在接口描述符里面又定 ...

  10. 在DELPHI中显示GIF动画

    想没想过在DELPHI中显示GIF动画?Delphi的用户是非常幸运的,因为有免费控件可以使用.最著名的控件是Anders Melander编写的TGifImage,并提供完整的源程序.它原来的主页是 ...