MySql 主键和外键怎么使用?

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

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

多字段联合主键
在开发中还有一种情况很常见,就是将几个字段联合在一起作为主键,那这个在代码中怎么实现呢?
举个例子,我们将员工的名字和部门ID联合起来作为主键:
下面展示一些 内联代码片。
CREATE TABLE t_emp2
(name VARCHAR(32),deptId INT,salary FLOAT,PRIMARY KEY(name,deptId)
)
语句执行后,会将name和deptId字段组合成为表t_emp2的多字段组合主键。
主外键键用法&意义
外部关键字
在以后我们统一将外部关键字叫做外键,外键就是另一张表中的主键。
问:外键有啥用啊?
答:外键的主要作用就是保持数据的一致性,完整性。
再问:怎么保证的呢?
答:看图。

如图有两张表,classId是T_Student的外键,是T_class 表的主键, 如果我们要删除T_class 表中classId为1的字段,程序是会报错的,因为t_student表中有数据和classId为1的字段关联了,是不能删除的,这样子就保证了数据的一致性和完整性。
继续问: 那怎么才能删除呢?
接着答: 需要先删除T__student表中classId为1的两个字段。
如何给表添加外部关键字
在MySQL中给表中字段添加外键约束的语法规则如下:
- CONSTRAINT 外键名 FOREIGN KEY 字段名 REFERENCES 主表名(主键名)
举个例子:现在有两张表,t_emp、t_dept如下。
t_dept表
| 字段名称 | 数据类型 | 备注 |
|---|---|---|
| deptld | INT | 部门编号 |
| name | VARCHAR(22) | 部门名称 |
| location | VARCHAR(50) | 部门位置 |
t_emp表
| 字段名称 | 数据类型 | 备注 |
|---|---|---|
| id | INT | 员工编号 |
| name | VARCHAR(22) | 员工名称 |
| location | VARCHAR(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)
);
实际操作如图:

祝你成功,学的愉快!😊
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
