乐趣区

关于mysql:mysql面试子查询

子查问

1. 概念:

查问中嵌套查问,称为子查问。

-- 查问工资最高的员工信息

-- 1. 查问最高员工的工资是多少 
SELECT MAX(salary) FROM emp;

-- 2. 查问员工信息,并且工资等于 9000 的
SELECT * FROM emp WHERE emp.`salary`= 9000;

-- 一条 sql 就实现这个操作
SELECT * FROM emp WHERE emp.`salary`= (SELECT MAX(salary) FROM emp);

a+b=5
c+a+b
c+ (a+b)

2. 子查问的不同状况

1. 子查问的后果是单行单列的

-- 查问员工工资小于平均工资的人
SELECT  * FROM emp WHERE emp.`salary` < (SELECT AVG(salary) FROM emp);

2. 多行单列

-- 查问‘财务’和 '市场' 部的所有的员工信息
SELECT id FROM dept WHERE NAME='财务部' OR NAME = '市场部';
SELECT * FROM emp WHERE dept_id=3 OR dept_id=2;
-- 子查问
SELECT * FROM emp WHERE dept_id IN (SELECT id FROM dept WHERE NAME='财务部' OR NAME = '市场部');

3. 多行多列

-- 查问员工入职日期是 2011-11-11 日之后的员工信息和部门信息
-- 子查问
SELECT * FROM dept t1,(SELECT * FROM emp WHERE emp.`join_date` > '2011-11-11') t2 WHERE t1.`id` = t2.dept_id;
SELECT * FROM emp WHERE emp.`join_date` > '2011-11-11';
-- 一般的内连贯
SELECT * FROM emp t1,dept t2 WHERE t1.`dept_id` = t2.`id` AND t1.`join_date` > '2011-11-11';  
退出移动版