mysql-面试-子查询
Posted 8s7k82mu
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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\';
以上是关于mysql-面试-子查询的主要内容,如果未能解决你的问题,请参考以下文章