MySQL多表查询之(内连接)

查看本文先需要明白多表查询的概念
如果不太清楚可以先查看我的文章
MySQL多表查询基础

内连接主要分为 隐式内连接 和 显式内连接

我们这里有两张表
department 部门表
在这里插入图片描述
staff员工表
在这里插入图片描述
相信大家都看出来了 这是个一对多的外键关系 而员工表的departmentid就是部门表的外键

然后我们先来看 隐式内连接
基本语法
select 字段列表 from 表名,表名 where 条件;

例如 我们这里就用隐式内连接 对员工和部门表进行连表查询

select * from staff,department where staff.departmentid = department.id;

运行结果如下
在这里插入图片描述
大家会发现 只有一条数据
因为张三并没有关联任何部门 自然就被条件过滤掉了
在这里插入图片描述
那我这个星号查全部有点太多余了 我们指想看用户和对应部门呢?
我们改成这样

select staff.name,department.name from staff,department where staff.departmentid = department.id;

运行结果如下
在这里插入图片描述

然后是 显式内连接
局部 语法是
select 字段列表 from 表1 inner join 表2 on 条件;
我们用 显式内连接实现一下刚才的语法

select staff.name,department.name from staff inner join department on staff.departmentid = department.id;

运行结果如下
在这里插入图片描述
没有任何问题
还有一个点
显式内连接中的inner是可以不写的

select staff.name,department.name from staff join department on staff.departmentid = department.id;

运行结果如下
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_45966674/article/details/127253225