MySQL-4多表操作

MySQL-4多表操作

多表关系

一对一

  • 在任一表中添加唯一外键,指向另一方主键,确保一对一关系。
  • 一个学生只有一张身份证;一张身份证只能对应一学生。
  • 一般一对一关系很少见,遇到一对一关系的表最好是合并表。

image-20220103203650803

一对多/多对一

  • 实现原则:在多的一方建立外键,指向一的一方的主键

  • 部门和员工

    • 分析:
    • 一个部门有多个员工,
    • 一个员工只能对应一个部门

image-20220103203604180

多对多

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

image-20220103204128358

外键约束

介绍

  • MySQL 外键约束(FOREIGN KEY)是表的一个特殊字段,
    • 经常与主键约束一起使用。
  • 对于两个具有关联关系的表而言,
    • 相关联字段中主键所在的表就是主表(父表),
    • 外键所在的表就是从表(子表)。
  • 外键用来建立主表与从表的关联关系,
    • 为两个表的数据建立连接,
    • 约束两个表中数据的一致性完整性
    • 比如:
      • 一个水果摊,只有苹果、桃子、李子、西瓜等 4 种水果,
      • 那么,你来到水果摊要买水果就只能选择苹果、桃子、李子和西瓜,
      • 其它的水果都是不能购买的。

image-20220103204719420

特点

定义外键时,遵守下列规则

  • 主表必须已经存在于数据库中
    • 或者是当前正在创建的表。
  • 必须为主表定义主键。
  • 主键不能包含空值,但允许在外键中出现空值。
  • 也就是说,只要外键的每个非空值出现在指定的主键中
  • 这个外键的内容就是正确的。
  • 在主表的表名后面指定列名或列名的组合。
  • 这个列或列的组合必须是主表的主键或候选键。
  • 外键中列的数目必须和主表的主键中列的数目相同。
  • 外键中列的数据类型必须和主表主键中对应列的数据类型相同。

操作-创建外键约束

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

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

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

实现
create database mydb3;  -- 创建数据库
use mydb3;
-- 创建部门表
create table if not exists dept(
  deptno varchar(20) primary key ,  -- 部门号
  name varchar(20) -- 部门名字
);

image-20220103210128387

-- 创建员工表
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) –- 外键约束
);

image-20220103210244685

两个表的关系如下

点击【文件】–【新架构设计器】–把表拖进来,就可以看到主外键关系图

image-20220103212231263

方式2-在创建后设置外键约束

  • 外键约束也可以在修改表时添加,
  • 但是添加外键约束的前提是:
    • 从表中外键列中的数据必须与主表中主键列中的数据一致
    • 或者是没有数据。
格式
alter table <数据表名> add constraint <外键名> foreign key(<列名>) references 
<主表名> (<列名>);

实现
-- 创建部门表
create table if not exists dept2(
  deptno varchar(20) primary key ,  -- 部门号
  name varchar(20) -- 部门名字
);
-- 创建员工表
create table if not exists emp2(
  eid varchar(20) primary key , -- 员工编号
  ename varchar(20), -- 员工名字
  age int,  -- 员工年龄
  dept_id varchar(20)  -- 员工所属部门
 
);


image-20220103213518216

-- 创建外键约束
alter table emp2 add constraint dept_id_fk foreign key(dept_id) references dept2 (deptno);

image-20220103213704657

image-20220103213741490

数据插入

添加主表数据

 -- 1、添加主表数据
 -- 注意必须先给主表添加数据
insert into dept values('1001','研发部');
insert into dept values('1002','销售部');
insert into dept values('1003','财务部');
insert into dept values('1004','人事部');

image-20220103214041230

添加从表数据

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值