登录
首页 >  数据库 >  MySQL

mysql-面试-子查询

来源:SegmentFault

时间:2023-02-25 10:42:22 497浏览 收藏

本篇文章向大家介绍《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` 

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-面试-子查询》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于mysql的知识点!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表