MySQL中连接查询和子查询的问题
来源:脚本之家
时间:2022-12-29 13:42:42 256浏览 收藏
知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个数据库开发实战,手把手教大家学习《MySQL中连接查询和子查询的问题》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!
多表连接的基本语法
多表连接,就是将几张表拼接为一张表,然后进行查询
select 字段1, 字段2, ... from 表1 {inner|lift|right} join 表2 on 连接条件;
有如下两张表:部门表和员工表
交叉连接和笛卡尔积现象
交叉连接
交叉连接,又名无条件内连接/笛卡尔连接
第一张表种的每一项会和另一张表的每一项依次组合
select * from employee,department;
上述结果肯定不是我们想晓得的,左表中每一个人都有4个部门,仔细观察这4条记录,正好是左表每一条记录和右表一一匹配后的结果。
笛卡尔积现象
笛卡尔积现象产生的原因:两张表没有有效的连接条件。既然你没有连接条件,本表中的第一行肯定是能和另外表中的所有行进行一一匹配,同理,本表中的第二行肯定是能和另外表中的所有行进行一一匹配,以此类推,本表中的最后一行m也可以和另外表中的所有行进行一一匹配。若另外一张表有n行,那么最后显示的行数,肯定就是m*n行了。
如果不想产生笛卡尔积现象,就需要添加有效的表连接条件。拿上述例子来说,左表dep_id只有和右表id相等时,才代表他们的部门。
内连接
内连接(INNER JOIN)是找几张表的交集,即根据条件筛选出来正确的结果。
select emp.id,emp.name,emp.age,emp.dep_id,emp.gender,dep.id,dep.name from employee as emp INNER JOIN department as dep on emp.dep_id=dep.id;
由于部门表中没有id=5
的部门,所以员工表dep_id=5
的这条记录没有返回;而由于行政部
没有员工,所以这条记录也没返回。
外连接
左外连接
左连接(left join)是以左表为准,如果右表中没有合适的记录,用NULL
补全;其本质是在内连接的基础上增加左表有结果而右表没有的记录(内连接时,这种情况的记录会忽略)。
select emp.id,emp.name,emp.age,emp.dep_id,emp.gender,dep.id,dep.name from employee as emp left join department as dep on emp.dep_id=dep.id;
右外连接
跟左连接正好相反,右连接(right join)是以右表为准,如果左表中某些字段没有合适的结果,用NULL
补全;其本质是在内连接的基础上增加右表有结果而左表没有的记录(内连接时,这种情况的记录会忽略)。
select emp.id,emp.name,emp.age,emp.dep_id,emp.gender,dep.id,dep.name from employee as emp right join department as dep on emp.dep_id=dep.id;
全外连接
全外连接,在内连接的基础上,展示左右表的所有的记录,而左右表中缺省记录以NULL
补全。
MySQL中并没有全外连接的FULL JOIN
语法,而是借助UNION/UNION ALL
语句实现。
UNION
和UNION ALL
的区别,UNION
具有去重功能。
select emp.id,emp.name,emp.age,emp.dep_id,emp.gender,dep.id,dep.name from employee as emp left join department as dep on emp.dep_id=dep.id union select emp.id,emp.name,emp.age,emp.dep_id,emp.gender,dep.id,dep.name from employee as emp right join department as dep on emp.dep_id=dep.id;
子查询
- 子查询是将一个查询语句嵌套再另一个查询语句中的查询方式:
- 子查询的内层查询结果,可以作为外层查询语句提供查询条件。
- 子查询中可以包含
IN
、NOT IN
、AND
、ALL
、EXISTS
、NOT EXISTS
等关键字。
子查询中还可以包含比较运算符,如=
、!=
、>
、等。
-- 查询平均年龄在20以上的部门名称 select name from department where id in ( select dep_id from employee group by dep_id having avg(age) > 20); -- 查询财务部员工姓名 select name from employee where dep_id in ( select id from department where name='财务部'); -- 查询所有大于平均年龄的员工的年龄和姓名 select name,age from employee where age > ( select avg(age) from employee);
理论要掌握,实操不能落!以上关于《MySQL中连接查询和子查询的问题》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!
-
489 收藏
-
209 收藏
-
497 收藏
-
335 收藏
-
467 收藏
-
303 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习
-
- 粗暴的小松鼠
- 这篇技术文章真及时,细节满满,真优秀,已收藏,关注楼主了!希望楼主能多写数据库相关的文章。
- 2023-03-15 14:42:23
-
- 受伤的冬瓜
- 好细啊,码起来,感谢博主的这篇技术贴,我会继续支持!
- 2023-02-24 04:45:06
-
- 明理的故事
- 赞 👍👍,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢大佬分享博文!
- 2023-01-31 06:05:28
-
- 哭泣的铅笔
- 这篇技术文章太及时了,师傅加油!
- 2023-01-11 18:11:37
-
- 大气的鲜花
- 这篇文章真及时,太全面了,受益颇多,已加入收藏夹了,关注up主了!希望up主能多写数据库相关的文章。
- 2023-01-10 04:29:23
-
- 快乐的小鸽子
- 这篇文章真是及时雨啊,细节满满,感谢大佬分享,码起来,关注作者大大了!希望作者大大能多写数据库相关的文章。
- 2023-01-06 19:37:05
-
- 等待的云朵
- 真优秀,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢大佬分享技术贴!
- 2023-01-04 14:37:08
-
- 傲娇的小蝴蝶
- 这篇技术文章太及时了,作者大大加油!
- 2023-01-04 09:10:42
-
- 知性的酸奶
- 太全面了,码住,感谢老哥的这篇博文,我会继续支持!
- 2022-12-30 01:10:47