MySql中子查询内查询示例详解
来源:脚本之家
2022-12-30 16:58:49
0浏览
收藏
本篇文章主要是结合我之前面试的各种经历和实战开发中遇到的问题解决经验整理的,希望这篇《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<any select salary from employees where job_id="IT_PROG"><p style="text-align: center"><img alt="" loading="lazy" src="/uploads/20221230/167239084463aea8bcc793c.png"></p> <pre class="brush:sql;"> 用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 <pre class="brush:sql;"> #案例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<all select distinct salary from employees where job_id="IT_PROG" and> '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';</all>

#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删除
MySql中流程控制函数/统计函数/分组查询用法解析
- 上一篇
- MySql中流程控制函数/统计函数/分组查询用法解析
- 下一篇
- 简单了解MySQL数据库优化技巧
查看更多
最新文章
-
- 数据库 · MySQL | 1天前 |
- MySQL数值函数大全及使用技巧
- 117浏览 收藏
-
- 数据库 · MySQL | 2天前 |
- 三种登录MySQL方法详解
- 411浏览 收藏
-
- 数据库 · MySQL | 3天前 |
- MySQL数据备份方法与工具推荐
- 420浏览 收藏
-
- 数据库 · MySQL | 3天前 |
- MySQL数据备份方法与工具推荐
- 264浏览 收藏
-
- 数据库 · MySQL | 4天前 |
- MySQL索引的作用是什么?
- 266浏览 收藏
-
- 数据库 · MySQL | 5天前 |
- MySQL排序原理与实战应用
- 392浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQLwhere条件查询技巧
- 333浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL常用数据类型有哪些?怎么选更合适?
- 234浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL常用命令大全管理员必学30条
- 448浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL高效批量插入数据方法大全
- 416浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL性能优化技巧大全
- 225浏览 收藏
-
- 数据库 · MySQL | 1星期前 |
- MySQL数据备份4种方法保障安全
- 145浏览 收藏
查看更多
课程推荐
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
查看更多
AI推荐
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 3167次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 3380次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 3409次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 4513次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 3789次使用
查看更多
相关文章
-
- MySQL子查询详细教程
- 2022-12-29 399浏览
-
- MySql数据库基础之子查询详解
- 2022-12-29 453浏览
-
- MySQL子查询的使用详解下篇
- 2022-12-30 442浏览
-
- MySQL嵌套查询实现子查询的方法
- 2022-12-29 222浏览
-
- Mysql中的嵌套子查询问题
- 2023-02-24 384浏览

