MySql 主键和外键怎么使用?

本文深入解析了数据库中主键和外键的概念及其应用,包括主键的定义方式、多字段联合主键的实现,以及外键如何维护数据一致性和完整性的原理。通过实例展示了在MySQL中创建和使用主键及外键的方法。
该文章已生成可运行项目,

时间煮雨
@R星校长

MySql主键&外键

主键用法&意义

主键,是表中一列或者多列的组合,主键约束(Primary Key Constraint)要求主键列的数据唯一,并且不允许为空,主键能够唯一的标识表中的每一条记录,可以结合外键来定义与不同数据表之间的关系。
怎么理解主键呢?我们知道数据库中的表可以存放很多数据,如果把表中的每一个数据比作一个人的话,那么表的主键就可以看做是人的身份证。

(1) 在定义列的同时指定主键:

在这里插入图片描述

(2) 在定义完所有列之后指定主键。

在这里插入图片描述

多字段联合主键

在开发中还有一种情况很常见,就是将几个字段联合在一起作为主键,那这个在代码中怎么实现呢?
举个例子,我们将员工的名字和部门ID联合起来作为主键:
下面展示一些 内联代码片

CREATE TABLE t_emp2
(
    name VARCHAR(32),
    deptId INT,
    salary FLOAT,
    PRIMARY KEY(name,deptId)
)

语句执行后,会将namedeptId字段组合成为表t_emp2的多字段组合主键。

主外键键用法&意义
外部关键字

在以后我们统一将外部关键字叫做外键,外键就是另一张表中的主键

问:外键有啥用啊?
答:外键的主要作用就是保持数据的一致性,完整性。

再问:怎么保证的呢?
答:看图。
在这里插入图片描述
如图有两张表,classIdT_Student的外键,是T_class 表的主键, 如果我们要删除T_class 表中classId1的字段,程序是会报错的,因为t_student表中有数据和classId1的字段关联了,是不能删除的,这样子就保证了数据的一致性和完整性

继续问: 那怎么才能删除呢?
接着答: 需要先删除T__student表中classId为1的两个字段。

如何给表添加外部关键字

在MySQL中给表中字段添加外键约束的语法规则如下:

  1. CONSTRAINT 外键名 FOREIGN KEY 字段名 REFERENCES 主表名(主键名)

举个例子:现在有两张表,t_empt_dept如下。

t_dept表

字段名称数据类型备注
deptldINT部门编号
nameVARCHAR(22)部门名称
locationVARCHAR(50)部门位置

t_emp表

字段名称数据类型备注
idINT员工编号
nameVARCHAR(22)员工名称
locationVARCHAR(50)部门ID(外键类型必须和对应主键类型一致)

我们来创建两张表,并给员工表(t_emp)添加外键:

CREATE TABLE t_dept
(
    deptId INT PRIMARY KEY,
    name VARCHAR(22),
    location VARCHAR(50)
);
CREATE TABLE t_emp
(
    id INT PRIMARY KEY,
    name VARCHAR(22),
    deptId INT,
    CONSTRAINT fk_emp_dept1 FOREIGN KEY(deptId) REFERENCES t_dept(deptId)
);

实际操作如图:
在这里插入图片描述

祝你成功,学的愉快!😊

本文章已经生成可运行项目
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值