开始MySQL之路——外键关联和多表联合查询详细概述

多表查询和外键关联

实际开发中,一个项目通常需要很多张表才能完成。例如,一个商城项目就需要分类表,商品表,订单表等多张表。且这些表的数据之间存在一定的关系,接下来我们将在单表的基础上,一起学习多表方面的知识。

开始MySQL之路——外键关联和多表联合查询详细概述_第1张图片

多表关系

MySQL多表之间的关系可以概括为:

一对一关系
  • 一个学生只有一张身份证;一张身份证只能对应一学生。

  • 在任一表中添加唯一外键,指向另一方主键,确保一对一关系。

  • 一般一对一关系很少见,遇到一对一关系的表最好是合并表。

开始MySQL之路——外键关联和多表联合查询详细概述_第2张图片

一对多/多对一关系

部门和员工

分析:一个部分有多个员工,一个员工只能对应一个部门,实际原则:在多的一方建立外键,指向一的一方。

开始MySQL之路——外键关联和多表联合查询详细概述_第3张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第4张图片

多对多关系

学生和课程

分析:一个学生可以选择很多门课程,一个课程也可以被很多学生选择,原则:多对多关系实际需要借助第三张中间表。中间表至少包含两个字段,将多对多的关系,拆成一对多的关系,中间表至少要有两个外键,这两个外键分别指向原来的那张两张表的主键

 

外键约束

介绍

MySQL外键约束(FOREIGN KEY)是表的一个特殊字段,经常与主键约束一起使用。对于两个具有关联关系的表而言,相关联字段中主键所在的表就是主表(父表),外键所在的表就是从表(子表)。

外键用来建立主表与从表的关联关系,为两个表的数据简历连接,约束两个表中数据的一致性和完整性。比如,一个水果摊,只有苹果,桃子,李子,西瓜等4种水果,那么,你来到水果摊要买水果只能选择苹果,桃子,李子和西瓜,其它的水果都是不能购买的。

特点

定义一个外键时,需要遵循下列规则:

  1. 主表必须已经存在于数据库中,或者是当前正在创建的表。

  2. 必须为主表定义主键。

  3. 主键不能包含空值,但允许在外键中出现空值。也就是说,只有外键的每个非空值出现在指定的主键中,这个外键的内容就是正确的。

  4. 在主键的表名后面指定列名或列名的组合。这个列或列的组合必须是主表的主键或候选键。

  5. 在外键中的数目必须和主键的主键中列的数目相同。

  6. 外键中列的数据类型必须和主表主键中对应列的数据类型相同。

创建外键约束-第一种方式

方式一:在创建表时设置外键约束

在create table语句中,通过foreign key关键字来指定外键,具体的语法格式如下:

[constraint<外键名>] foreign key 字段名[,字段名2,...] references<主键名> 主键列1 [,主键列2,...]

实现:

create database mydb3;
use mydb3;
-- 创建部门表
create table if not exists dept(
  depton varchar(20) primary key, -- 部门号
  name varchar(20) --部门名字
);

方式1-在创建表时设置外键约束

create table if not exists emp(
eid varchar(20) primary key,-- 员工编号
ename varchar(20), -- 员工名字
age  int,-- 员工年龄
dept_id varchar(20), --员工所属部门
constaraint emp_fk foreign key(dept_id) references dept(deptno) -- 外键约束
);

代码实现

外键约束
create database mydb3;
use mydb3;

创建部门表
create table if not exists dept(
   deptno varchar(20) primary key, -- 部门编号
   name varchar(20) -- 部门名字
);

创建员工表,并创建外键约束 -方式1
[constraint<外键名> ] foreign key 字段名 [,字段名2,...] references<主表名> 主键列1[,主键列2,...]

create table if not exists emp(
eid varchar(20) primary key, -- 员工编号
ename varchar(20),-- 员工姓名
age int ,-- 员工年龄
dept_id varchar(20), -- 员工所属部门
constraint emp_fk foreign key (dept_id) references dept(deptno)
);

创建外键约束-第二种方式

外键约束也可以在修改表时添加,但是添加外键约束的前提是:才表中外键列中的数据必须与主表中主键列中的数据一致或者是没有数据。

alter table <数据表名> add constarint <外键名> foreign key(<列名>) references <主表名>(<列名>);

开始MySQL之路——外键关联和多表联合查询详细概述_第5张图片

在外键约束下的数据操作

开始MySQL之路——外键关联和多表联合查询详细概述_第6张图片

删除外键约束

开始MySQL之路——外键关联和多表联合查询详细概述_第7张图片

多对多关系

开始MySQL之路——外键关联和多表联合查询详细概述_第8张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第9张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第10张图片开始MySQL之路——外键关联和多表联合查询详细概述_第11张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第12张图片

多表联合查询

开始MySQL之路——外键关联和多表联合查询详细概述_第13张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第14张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第15张图片

 开始MySQL之路——外键关联和多表联合查询详细概述_第16张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第17张图片开始MySQL之路——外键关联和多表联合查询详细概述_第18张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第19张图片

内连接查询

开始MySQL之路——外键关联和多表联合查询详细概述_第20张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第21张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第22张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第23张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第24张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第25张图片 

开始MySQL之路——外键关联和多表联合查询详细概述_第26张图片

外连接查询

开始MySQL之路——外键关联和多表联合查询详细概述_第27张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第28张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第29张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第30张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第31张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第32张图片

子查询

开始MySQL之路——外键关联和多表联合查询详细概述_第33张图片

①:基本子查询

开始MySQL之路——外键关联和多表联合查询详细概述_第34张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第35张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第36张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第37张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第38张图片开始MySQL之路——外键关联和多表联合查询详细概述_第39张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第40张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第41张图片

②:all关键字

开始MySQL之路——外键关联和多表联合查询详细概述_第42张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第43张图片

③:Any和some

开始MySQL之路——外键关联和多表联合查询详细概述_第44张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第45张图片

④:in

开始MySQL之路——外键关联和多表联合查询详细概述_第46张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第47张图片

⑤:Exists

开始MySQL之路——外键关联和多表联合查询详细概述_第48张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第49张图片

自关联查询

开始MySQL之路——外键关联和多表联合查询详细概述_第50张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第51张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第52张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第53张图片

开始MySQL之路——外键关联和多表联合查询详细概述_第54张图片

你可能感兴趣的:(mysql数据库,mysql,oracle,数据库)