尚硅谷之MySQL基础

第13章 子查询

某些情况下,当进行一个查询时,需要的条件或数据要用另外一个 select 语句的结果,这个时候,就要用到子查询。

例如:

为了给主查询(外部查询)提供数据而首先执行的查询(内部查询)被叫做子查询。

一般根据子查询的嵌入位置分为,where型子查询,from型子查询,exists型子查询。

1、where型子查询

where型子查询即把内层sql语句查询的结果作为外层sql查询的条件.

  • 子查询要包含在括号内。
  • 建议将子查询放在比较条件的右侧。
  • 单行操作符对应单行子查询,多行操作符对应多行子查询。
    • 单行操作符  右边子查询必须返回的是单个值,单行比较运算符(=,>,>=,<,<=,<>)
    • 多行操作符 右边子查询可以返回多行,但必须是单列,ALL, ANY,IN 其中,ALL和ANY运算符必须与单行比较运算符(=,>,>=,<,<=,<>)结合使用

  IN:等于任何一个

  ALL:和子查询返回的所有值比较。例如:sal>ALL(1,2,3)等价于sal>1 && sal>2 && sal>3,即大于所有。

  ANY:和子查询返回的任意一个值比较。例如:sal>ANY(1,2,3)等价于sal>1 or sal>2 or sal>3,即大于任意一个就可以。

  EXISTS:判断子查询是否有返回结果(不关心具体行数和内容),如果返回则为TRUE,否则为FALSE。

#子查询

#where型子查询

#查询比“孙红雷”的工资高的员工编号

SELECT * FROM t_salary

WHERE basic_salary > (SELECT basic_salary FROM t_employee INNER JOIN t_salary ON t_employee.eid=t_salary.eid WHERE t_employee.ename='孙红雷');

#查询和孙红雷,李晨在同一个部门的员工

SELECT * FROM t_employee

WHERE dept_id IN(SELECT dept_id FROM t_employee WHERE ename='孙红雷' OR ename = '李晨');

SELECT * FROM t_employee

WHERE dept_id = ANY(SELECT dept_id FROM t_employee WHERE ename='孙红雷' OR ename = '李晨');

#查询全公司工资最高的员工编号,基本工资

SELECT eid,basic_salary FROM t_salary

WHERE basic_salary = (SELECT MAX(basic_salary) FROM t_salary);

SELECT eid,basic_salary FROM t_salary

WHERE basic_salary >= ALL(SELECT basic_salary FROM t_salary);