一、外键:
就是把一张表的主键拿到另一张表中作为一个平凡的字段
通过外键 可以把两张表毗连起来
比如,下面【部门】表里的主键 拿到【员工】表里做平凡字段(外键)
员工 部门
1员工,XXX,1部门 1部门,武当派
2员工,XXX,2部门 2部门,峨眉派
3员工,XXX,1部门 3部门,明教
4员工,XXX,2部门
计划主外键关系的方案
1、图形化操作:(数据库管理工具)
2、写sql语句
constraint 束缚名 foreign key (外键列名) references 对方表(列表)
- -- 创建部门表
- create table dept(
- id int(10) not null primary key auto_increment,
- deptName varchar(50),
- deptLeader varchar(50)
- )
- -- 创建员工表(需要部门表的支持)
- create table emp(
- id int(10) not null primary key auto_increment,
- name varchar(50),
- salary decimal(10,2),
- deptNo int(10),
- constraint foreign_key_deptNo foreign key (deptNo) references dept(id)
- );
复制代码
二、多表查询
1、子查询
举例:
- 根据: 查询 where (表A 外键 in 表B)
- 题目1:通过部门的名称查询出该部门所有的员工信息——查询明教的员工信息
- -- 分解
- -- (1)查询明教的部门信息
- select id from dept where deptName = '明教'
- -- (2)根据ID查询员工信息
- select * from emp where deptNo = 3
- -- 结果
- select * from emp where deptNo = (select id from dept where deptName = '明教')
- -- ⚠️用in更适用 如果后面的查询结果不是唯一的 用 = 不合适
- select * from emp where deptNo in (select id from dept where deptName = '明教')
复制代码
- 同时查询两张表 表A.字段 表B.字段 where( 表A.外键字段 = 表B.主键字段)
- 题目2: 查询各个部门的平均工资
- -- 分解教学“各个部门的平均工资” 根据部门来区分,所以group by deptNo
- select avg(salary) from emp group by deptNo
- -- 但是⚠️希望展示部门 :部门 平均工资
- -- 把部门和员工放在一起进行查询
- select dept.deptName,avg(emp.salary) from emp,dept where emp.deptNo = dept.id group by dept.deptName
复制代码 2、关联查询
- 语法规则
- join:关联
- on: 通过 ... 做关联
- A xxjoin B on A.字段 = B.字段
- ⚠️通常关联项 on 背面的就是 主键 外键
- 用的比较多的还是inner join 、left join 左联
- inner join 内毗连
- left join 左联
- right join 右联 结果和左联也差不多
2.1、inner join 内毗连 筛选出两张表完全关联起来的数据
- -- 通常关联项 on 后面的就是 主 外 键
- SELECT * from dept INNER JOIN emp on dept.id = emp.deptNo
- -- inner JOIN 改成 下面的 子查询 结果一样
- SELECT * from dept,emp where emp.deptNo = dept.id
复制代码 2.2、left join 左联 一定会把左边表的数据全部查询出来
把左边这张表所有的数据都摆出来 根据关联项 把右边表的数据插入进去
- -- left join 一定会把左边表的数据全部查询出来
- SELECT * from emp left JOIN dept on dept.id = emp.deptNo
- ⚠️应用场景非常多,比如
- 查询所有员工的部门信息 ⚠️所有员工 以员工为基准 emp在左边
- -- 员工名字 部门名字
- select emp.name,dept.deptName from emp LEFT JOIN dept on dept.id = emp.deptNo
复制代码 结果如下:
2.3、right join 右联 一定会把右边表的数据全部查询出来
把右边这张表所有的数据都摆出来 根据关联项 把左边表的数据插入进去
- -- 右联接 一定把右边的数据查询出来
- SELECT * from emp RIGHT JOIN dept on emp.deptNo = dept.id
复制代码 结果如下:
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |