查看本文先需要明白多表查询的概念
如果不太清楚可以先查看我的文章
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;
运行结果如下