MySql中子查询内查询示例详解
来源:脚本之家
时间:2022-12-30 16:58:49 361浏览 收藏
本篇文章主要是结合我之前面试的各种经历和实战开发中遇到的问题解决经验整理的,希望这篇《MySql中子查询内查询示例详解》对你有很大帮助!欢迎收藏,分享给更多的需要的朋友学习~
西北望乡何处是,东南见月几回圆。
月亮又慢悠悠的挂上了天空,趁着睡前梦呓,我就带领各位可爱的读者们探索MySql最后的子查询部分。
说明:有些查询结果出来结果截图与题目要求不一样会出现多余的字段是为了方便展示结果的可读性。实际操作的读者可以删除SELECT后面多余的字段得到正确的结果。
#WHERE或HAVING后面 #1.标量子查询(单行子查询) #2.列子查询(多行子查询) #3.行子查询(多列多行) #特点: # ①子查询放在小括号内 # ②子查询一般放在条件的右侧 # ③标量子查询:一般搭配着单行操作符使用 # 单行操作符: > = !- # 列子查询,一般搭配着多行操作符使用 # IN,ANY/SOME(任意),ALL # ④子查询的执行优先与主查询执行,主查询的条件用到了子查询的结果。
#1.标量子查询 #案例1:谁的工资比Abel高? #①查询Abel的工资 SELECT salary FROM employees WHERE last_name = 'Abel';
#②查询员工的信息,满足Salary>①结果 SELECT * FROM employees WHERE salary>(SELECT salary FROM employees WHERE last_name='Abel');
#案例2.返回job_id与141号员工相同,salary比143号员工多的员工姓名,job_id,工资。 #①查141员工的job_id SELECT job_id FROM employees WHERE employee_id='141';
#②查143员工的salary SELECT salary FROM employees WHERE employee_id='143';
#③最后合并结果 SELECT CONCAT(last_name,first_name) AS 姓名, job_id AS 工种编号, salary AS 工资 FROM employees WHERE job_id=( SELECT job_id FROM employees WHERE employee_id='141' ) AND salary>( SELECT salary FROM employees WHERE employee_id='143' );
#案例3.返回公司工资最少的员工的last_name,job_id和salary。 SELECT MIN(salary) FROM employees;
SELECT last_name AS 姓, salary AS 工资, job_id AS 工种编号 FROM employees WHERE salary=( SELECT MIN(salary) FROM employees );
#案例4.查询最低工资大于50号部门最低工资的部门id和其最低工资。 #①查50部门的最低工资 SELECT MIN(salary) FROM employees WHERE department_id=50;
#分组后,筛选条件①.【不用排除没有部门的所以不筛选部门编号】 SELECT department_id AS 部门编号, MIN(salary) AS 月薪 FROM employees #WHERE department_id GROUP BY department_id HAVING 月薪>( SELECT MIN(salary) FROM employees );
#2.列子查询(多行子查询) #返回多行 #使用多行比较操作符
#案例1.返回location_id是1400或1700的部门中的所有员工姓名。 #①查询location_id是1400或1700的部门编号 SELECT DISTINCT department_id FROM departments WHERE location_id IN(1400,1700);
#②查询员工姓名,要求部门号是①列表的某一个 SELECT CONCAT(last_name,first_name) AS 姓名 FROM employees WHERE department_id IN ( SELECT DISTINCT department_id FROM departments WHERE location_id IN(1400,1700) );
用ANY替代IN与上面同样的结果 SELECT CONCAT(last_name,first_name) AS 姓名 FROM employees WHERE department_id = ANY( SELECT DISTINCT department_id FROM departments WHERE location_id IN(1400,1700) );
#案例.返回location_id不是1400或1700的部门中的所有员工姓名。 SELECT CONCAT(last_name,first_name) AS 姓名 FROM employees WHERE department_id NOT IN( SELECT DISTINCT department_id FROM departments WHERE location_id IN(1400,1700) ); ============================== SELECT CONCAT(last_name,first_name) AS 姓名 FROM employees WHERE department_id ALL( SELECT DISTINCT department_id FROM departments WHERE location_id IN(1400,1700) );
#案例2.返回其他工种中比job_id为IT_PROG部门任意一工资低的员工工号, # 姓名,job_id以及salary #①把IT_PROG部门中的工资查出来 SELECT DISTINCT salary FROM employees WHERE job_id='IT_PROG';
#②把不是IT_PROG部门信息查出来 SELECT * FROM employees WHERE job_id != 'IT_PROG';
#③合并①与②在员工表中查出来 SELECT employee_id AS 员工编号, CONCAT(last_name,first_name) AS 姓名, job_id AS 工种编号, salary AS 工资 FROM employees WHERE job_id != 'IT_PROG' AND salary 用MAX代替ANY与上面同样的效果 SELECT employee_id AS 员工编号, CONCAT(last_name,first_name) AS 姓名, job_id AS 工种编号, salary AS 工资 FROM employees WHERE job_id 'IT_PROG' AND salary#案例3.返回其他部门中比job_id为‘IT_PROG'部门所有工资都低的员工 #的员工号,姓名,job_id以及salary。 #①先把IT_PROG部门的工资查出来。 SELECT DISTINCT salary FROM employees WHERE job_id='IT_PROG';SELECT employee_id AS 员工号, CONCAT(last_name,first_name) AS 姓名, job_id AS 工种编号, salary AS 工资 FROM employees WHERE salary'IT_PROG'; ============================= MIN替代ALL SELECT employee_id AS 员工号, CONCAT(last_name,first_name) AS 姓名, job_id AS 工种编号, salary AS 工资 FROM employees WHERE salary 'IT_PROG'; #3.行子查询(结果集一行多列或者多行多列) #案例1.查询员工编号最小并且工资最高的员工信息.引入 SELECT MIN(employee_id) FROM employees; ================= SELECT MAX(salary) FROM employees;SELECT * FROM employees WHERE employee_id = ( SELECT MIN(employee_id) FROM employees ) AND salary = ( SELECT MAX(salary) FROM employees );这种查询结果使用虚拟字段,单行操作符必须一致可以使用。查出来与上面同样的效果。 SELECT * FROM employees WHERE (employee_id,salary)=( SELECT MIN(employee_id), MAX(salary) FROM employees );#二.SELECT子查询 #仅仅支持标量子查询,结果是一行一列 #案例1.查询每个部门的员工个数 SELECT d.*,(SELECT COUNT(*) FROM employees) FROM departments d;添加条件 SELECT d.*,(SELECT COUNT(*) FROM employees e WHERE e.department_id=d.department_id ) AS 个数 FROM departments d;#案例2.查询员工号=102的部门名。 SELECT department_name FROM departments; ============== SELECT employee_id FROM employees WHERE employee_id = 102;SELECT employee_id, ( SELECT department_name FROM departments d WHERE e.department_id=d.department_id ) FROM employees e WHERE employee_id=102;#三.FROM 后面 注意:将子查询结果充当一张表,要求必须起别名 #案例:查询每个部门的平均工资等级。 SELECT ROUND(AVG(salary),2),department_id FROM employees GROUP BY department_id;SELECT e.平均工资,j.grade_level FROM job_grades AS j ,( SELECT ROUND(AVG(salary),2) AS 平均工资,department_id FROM employees GROUP BY department_id ) AS e WHERE e.平均工资 BETWEEN j.lowest_sal AND j.highest_sal;#1999语法,老师答案 SELECT e.*,j.grade_level FROM ( SELECT ROUND(AVG(salary),2) AS 平均工资,department_id FROM employees GROUP BY department_id ) AS e INNER JOIN job_grades j ON e.平均工资 BETWEEN j.lowest_sal AND j.highest_sal;#四.EXISTS后面(相关子查询) 语法:EXISTS(完整的查询语句) 备注:完整的查询语句可以是一行一列,可以使一行多列 注意:先走外查询,然后根据某个字段的值再去过滤 EXISTS 判断(布尔类型)值存不存在,结果只有两种:1有,0没有 #引入 SELECT EXISTS(SELECT employee_id FROM employees);查询工资3W的员工信息 SELECT EXISTS(SELECT * FROM employees WHERE salary=30000);#案例引入.查询员工名和部门名 #查员工名与部门编号 SELECT first_name,department_id FROM employees WHERE department_id;#查部门名 SELECT department_name FROM departments;#查员工名与部门名 SELECT e.first_name,d.department_name FROM employees e INNER JOIN ( SELECT department_name,department_id FROM departments ) AS d ON e.department_id=d.department_id;#案例1..查有员工的部门名 SELECT department_name FROM departments d WHERE EXISTS( SELECT * FROM employees e WHERE d.department_id=e.department_id );使用IN代替EXISTS,同样是上面的结果 SELECT department_name FROM departments d WHERE d.department_id IN( SELECT department_id FROM employees );#案例2.查询没有女朋友的男神信息 #IN方法 SELECT * FROM boys bo WHERE bo.id NOT IN( SELECT boyfriend_id FROM beauty be ); =============== #EXISTS方法 SELECT * FROM boys bo WHERE NOT EXISTS( SELECT boyfriend_id FROM beauty be WHERE bo.id=be.boyfriend_id );进阶9:联合查询 UNION 联合 合并:将多条查询语句的结果合并成一个结果。 语法: 查询语句1 UNION 查询语句2 UNION ... 应用场景: 要查询的结果来自于多个表,且多个表没有直接的连接关系, 但查询信息一致时。 网页搜索内容,内容从不同的表中检索联合起来返回给用户。 特点: 1.要求多条查询语句的查询列数是一致的。 2.要求多条查询语句的查询的每一列的类型和顺序最好一致。 3.使用UNION关键字默认去重,如果使用UNION ALL全部展示,包含重复项感谢能认真读到这里的伙伴们,MySql查询部分结束,相信屏幕前的你照着我博客里的模板可以完成一些简单的SQL查询语句,SQL既然学了,以后还是要多练习一下,SQL1992与1999语法在主流的关系型数据库都是通用的。后续我会继续进行对MySql的知识进行扩展,感兴趣的同志互相关注一呗!o(^▽^)o
今天带大家了解了mysql子查询、内查询的相关知识,希望对你有所帮助;关于数据库的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
声明:本文转载于:脚本之家 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
-
399 收藏
-
453 收藏
-
442 收藏
-
222 收藏
-
384 收藏
最新阅读
更多>
-
476 收藏
-
312 收藏
-
244 收藏
-
195 收藏
-
334 收藏
-
420 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习