百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>数据库> mysql的多表查询细致解说
分享文章到:

mysql的多表查询细致解说

发布时间:09/01 来源:未知 浏览: 关键词:
第一,为了利便说明问题,创立两个表emp(雇员信息)和dept(雇员部门信息),其数据如下:

20180617221923394.png在此前的文章中,我们分享了单表查询的办法,但是在实际利用中,我们要查的数据很大概不在统一个表中,而是来自于不一样的表。多表查询假如不加任何前提,得到的结果称为笛卡尔积。 例如,查寻雇员名、雇员薪水乃至部门所在的名字。

2018061722200051.png

可以发明,结果是这样的,从第一个表中选出第一笔记录,和第二个表中的所有所有记载停止组合,然后再从第一个表中取出第二笔记录,和第二张表的所有记载停止组合,这样的结果是没有实际意义的。我们需要的是emp.deptno = dept.deptno字段的记载。

20180617222017362.png

自连接

自连接是指在统一张表连接查询

显示员工FORD的上级领导的名字

20180617222734599.png

子查询

子查询是指嵌入在其他sql语句中的select语句,也叫嵌套查询。

单行子查询:子查询的查询结果只要一行

显示和SMITH统一部门的员工

20180617223344582.png

多行子查询(in ,all, any):返回多笔记录的子查询

查询和10好部门的工作雷同的官员的名字、工作、薪水、部门号,但是不包罗10号本人的信息

20180617224416375.png

显示薪水比部门编号为30的所有员工的薪水高的员工的姓名、薪水和部门号

20180617224738762.png

显示薪水比部门编号为30的任意员工的薪水高的员工的姓名、薪水和部门号

201806172249224.png

多列子查询:查询返回多个列数据的子查询语句

查询和SMITH的部门和岗位完全雷同的雇员,不含SMITH本人

20180617230327343.png

from子句中使用子查询

显示高于本人部门的均匀薪水的员工信息

20180617231541142.png查寻每个部门薪水最高的人的ename, job, sal

20180617231535796.png显示每个部门的信息(部门名、编号、地址)和人员数目

20180617232454580.png

这里有两种办法可以使用,但是经历证,当数据非常多的时候from子查询的效力是高于多表查询的。

删除表中的反复记载

已知一个表tt中有反复的数据

创立一张空表tmp_tt,空表的构造与表tt的构造雷同;create table tmp_tt like tt;

将tt表停止distinct,将数据导入空表中;insert into tmp_tt select distinct * from tt;

删除原表ttdrop table tt;

将tmp_tt改名为ttalter table tmp_tt rename tt;

合并查询

在实际利用中,为了合并多个select的施行结果,可以使用union,union all汇合操纵符

1、union操纵符用于取得两个结果的并集,并再主动去除反复行 ,查寻薪水大于2500和职位Manger的人

20180617233556266.png

2. union all 与union相似,但是不会主动去重
例如:与or相似

20180617234055522.png

外键

外键定义主表和从表的关系,外键束缚主如果定义在从表上,主表必需是有主键或者独一键。当定义外键后,要求外键列数据必需在主表列存在或者为NULL。
例如:创立一个主表class,从表stu

2018061723530193.png

20180617235528589.png

由上图,我们可以知道主键不克不及为null,但是外键可认为null,同时不克不及存在外键有的数据而主表中不存在。

更多相关问题请拜访PHP中文网:mysql视频教程

以上就是mysql的多表查询具体讲解的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有150人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板