mysql中 多表查询讲解_mysql的多表查询详细讲解

首先,为了方便说明问题,创建两个表emp(雇员信息)和dept(雇员部门信息),其数据如下:

3de2eee4e1637b482466c48ce4e1df77.png在之前的文章中,我们分享了单表查询的方法,但是在实际应用中,我们要查的数据很可能不在同一个表中,而是来自于不同的表。多表查询如果不加任何条件,得到的结果称为笛卡尔积。 例如,查找雇员名、雇员工资以及部门所在的名字。

faacec228e8cdd706fb781243876826f.png

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

2dd90868ee489b98d07751aae093ff61.png

自连接

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

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

0279f46be3216edb2555a6f1e4c7f6ce.png

子查询

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

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

显示和SMITH同一部门的员工

64488b9a9757142797b538c90dfe642f.png

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

查询和10好部门的工作相同的官员的名字、工作、工资、部门号,但是不包括10号自己的信息

146f78faee6045ea265c69671ebdacd3.png

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

43e0d55fb5afae212604242b427e5289.png

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

0c2274a7acf4e29d1000876480e382b0.png

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

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

f18eb43ece874bf8f1ee603b6c847d6b.png

from子句中使用子查询

显示高于自己部门的平均工资的员工信息

8388c9a1c544c0b6875e2de7dc499488.png查找每个部门工资最高的人的ename, job, sal

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

c8367377dce719850da18a1df0a0e086.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的人

6f3723b4d66dd122dedbb2141c285f75.png

2. union all 与union类似,但是不会自动去重

例如:与or类似

e53fde14750d2740157374e6118d7566.png

外键

外键定义主表和从表的关系,外键约束主要是定义在从表上,主表必须是有主键或者唯一键。当定义外键后,要求外键列数据必须在主表列存在或者为NULL。

例如:创建一个主表class,从表stu

4dbaf002e61e51aab562b6397b2fc28c.png

cfe7d09c8e91df2c265f7fa66e933904.png

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值