多表查询mysql

连表查询:总是在连接的时候创建一张大表,里面存放的是两张表的笛卡尔积。再根据条件进行筛选。
数据准备
在这里插入图片描述
笛卡尔集加条件约束,
department.id=dep_id 因为 department的id和employee中的id同名,所以在前面加了表名。
在这里插入图片描述
表与表之间的连接方式
select *from 表1,表2 where 条件
内连接:select *from 表1 inner join 表2 on 条件
外连接:左外连接,右外连接,全连接
左外连接:left join…on
select *from 表1 left join 表2 on 条件
在这里插入图片描述
全外连接,mysql中没有可以用union实现
在这里插入图片描述

找到技术部所有人的姓名
在这里插入图片描述

找到人力资源部的年龄大于40岁人的姓名

子查询
求每个部门有多少人

这个部门没有显示运营部门的人,是不对的
在这里插入图片描述
count(d.id)是不对的,因为运营部没人
在这里插入图片描述count(e.id)是对的,一般情况都是count主键
在这里插入图片描述
求每一个部门有多少人并按照人数从高到低排序
在这里插入图片描述
连表就是把两张表连接在一起之后,就变成一张达标,从from开始一直到on条件结束就看作一张表,之后where条件,group by,分组,order by limit 都可以正常使用了

子查询
带in关键字的子查询
查询平均年龄在25岁以上的部门名
在这里插入图片描述
查看技术部门员工姓名
先查询技术部的部门id
再根据这个部门id找到对应的员工名
在这里插入图片描述
in可以换成=在这里插入图片描述

查看不足1人的部门名(子查询得到的是有人的部门id)
在这里插入图片描述

带比较运算符的查询
查询大于所有人平均年龄的员工名与年龄
在这里插入图片描述

查询大于部门内平均年龄的员工名、年龄
在这里插入图片描述
exists
表示存在,使用exists关键字时,内层查询语句不返回查询的记录。而是返回一个真假值。True或False。当返回True时,外层查询语句将进行查询,当返回False时,外层查询语句不进行查询。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL多表查询是指在MySQL数据库同时操作多个进行数据查询的过程。通过多表查询,可以将多个的数据连接在一起,实现更复杂的查询功能。 多表查询的实验可以按照以下步骤进行: 1. 创建多个:首先需要创建两个或多个关联的数据,这些可以通过外键进行关联。例如,可以创建一个学生(Student)和一个课程(Course),并且在课程添加一个外键来关联学生的学生ID。 2. 插入数据:在创建后,需要向插入数据以便进行查询。通过插入数据,可以模拟真实的数据查询场景。 3. 编写查询语句:通过编写查询语句,可以实现多表查询的功能。多表查询可以使用关键字JOIN来连接多个,并且可以根据需要使用不同的连接方式,如内连接(INNER JOIN)或外连接(LEFT JOIN、RIGHT JOIN)等。 4. 运行查询语句:将编写好的查询语句在MySQL数据库运行,观察查询结果。如果查询结果符合预期,说明多表查询实验成功。 5. 进行数据分析:通过查询结果,可以进行数据分析和统计。可以使用聚合函数(如COUNT、SUM、AVG等)对查询结果进行计算,得出更有价值的数据分析结果。 在多表查询实验,还可以使用子查询、嵌套查询、联合查询等更复杂的查询方式,以满足实际需求。 通过多表查询实验,可以帮助我们更好地理解多个之间的关系,并且可以提高查询效率和准确性,为实际应用场景提供支持。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值