嵌套在其他语句内部的select语句称为子查询或内查询。 外面的语句可以是insert、update、delete、select等,一般select作为外面语句较多。 外面如果为select语句,则此语句称为外查询或主查询。
select后面:仅仅支持标量子查询 from后面:表子查询、 where或having后面:标量子查询、列子查询、行子查询 exists后面:标量子查询、列子查询、行子查询、表子查询
标量子查询(单行子查询):结果集为一行一列 列子查询(多行子查询):结果集为多行一列 行子查询:结果集为一行多列或多行多列 表子查询:结果集为多行多列
查询最低工资的员工姓名和工资
①查询最低工资
SELECT MIN(salary) FROM empoloyees;②查询员工的姓名和工资,要求工资=①
SELECT last_name,salary FROM employees WHERE salary=( SELECT MIN(salary) FROM employees );使用多行比较操作符 IN / NOT IN:等于列表中的任意一个 ANY / SOME:和子查询返回的某一个值比较 ALL:和子查询返回的所有值比较
查询 location_id是1400或1700的部门中的所有员工姓名
①查询 location_id是1400或1700的部门编号
SELECT DISTINCT department_id FROM departments WHERE location_id IN (1400,1700)②查询员工姓名,要求部门号是①列表中的某一个
SELECT last_name FROM employees WHERE department_id IN ( SELECT DISTINCT department_id FROM departments WHERE location_id IN (1400,1700) );查询每个部门的员工个数
SELECT d.*,( SELECT COUNT(*) FROM employees e WHERE e.department_id = d.department_id ) 个数 FROM departments d;