1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > MySQL 基础 -- 约束(非空约束 唯一约束 主键约束 默认约束 检查约束 外键约束)

MySQL 基础 -- 约束(非空约束 唯一约束 主键约束 默认约束 检查约束 外键约束)

时间:2024-06-16 21:17:28

相关推荐

MySQL 基础 -- 约束(非空约束 唯一约束 主键约束 默认约束 检查约束 外键约束)

1. 约束

概念:约束是作用于表中字段上的规则,用于限制存储在表中的数据。

目的:保证数据库中数据的正确、有效性和完整性。

约束分类:

1.1 约束演示:不含外键约束

案例需求: 根据需求,完成表结构的创建。需求如下:

对应的建表语句为:

CREATE TABLE tb_user(idint AUTO_INCREMENT PRIMARY KEY COMMENT 'ID唯一标识',name varchar(10) NOT NULL UNIQUE COMMENT '姓名',age int check (age > 0 && age <= 120) COMMENT '年龄',status char(1) default '1' COMMENT '状态',gender char(1) COMMENT '性别');

查看id的主键约束:

insert into tb_user(name, age, status, gender)values ('Tom1', 19, '1', '男'),('Tom2', 25, '0', '男');

查看name的非空且唯一的约束:

唯一约束:

insert into tb_user(name, age, status, gender)values ('Tom3', 19, '1', '男');insert into tb_user(name, age, status, gender)values ('Tom3', 19, '1', '男');

非空约束:

insert into tb_user(name, age, status, gender)values (null, 19, '1', '男');

查看age的check约束

insert into tb_user(name, age, status, gender)values ('Tom4', -1, '1', '男');

insert into tb_user(name, age, status, gender)values ('Tom4', 22, '1', '男');

查看status的默认约束:

insert into tb_user(name, age, gender)values ('Tom5', 120, '男');

1.2 说明

上面,我们是通过编写SQL语句的形式来完成约束的指定,那加入我们是通过图形化界面来创建表结构时,又该如何来指定约束呢? 只需要在创建表的时候,根据我们的需要选择对应的约束即可。

我这里使用的UI工具是DataGrip

1.3 外键约束

1.3.1 介绍

外键:用来让两张表的数据之间建立连接,从而保证数据的一致性和完整性。

我们来看一个例子:

左侧的emp表是员工表,里面存储员工的基本信息,包含员工的ID、姓名、年龄、职位、薪资、入职日期、上级主管ID、部门ID,在员工的信息中存储的是部门的IDdept_id,而这个部门的ID是关联的部门表dept的主键id,那emp表的dept_id就是外键,关联的是另一张表的主键。

注意目前上述两张表,只是在逻辑上存在这样一层关系;在数据库层面,并未建立外键关联,所以是无法保证数据的一致性和完整性的。

1.3.2 准备数据

# 创建dept表create table dept(id int auto_increment comment 'ID' primary key,name varchar(50) not null comment '部门名称') comment '部门表';# 往dept表里面插入初始数据INSERT INTO dept (id, name)VALUES (1, '研发部'),(2, '市场部'),(3, '财务部'),(4, '销售部'),(5, '总经办');# 创建emp表create table emp(id int auto_increment comment 'ID' primary key,namevarchar(50) not null comment '姓名',age int comment '年龄',job varchar(20) comment '职位',salary int comment '薪资',entrydate date comment '入职时间',managerid int comment '直属领导ID',dept_id int comment '部门ID') comment '员工表';# 往emp表里面插入初始数据INSERT INTO emp (id, name, age, job, salary, entrydate, managerid, dept_id)VALUES (1, '金庸', 66, '总裁', 20000, '2000-01-01', null, 5),(2, '张无忌', 20, '项目经理', 12500, '-12-05', 1, 1),(3, '杨逍', 33, '开发', 8400, '2000-11-03', 2, 1),(4, '韦一笑', 48, '开 发', 11000, '2002-02-05', 2, 1),(5, '常遇春', 43, '开发', 10500, '-09-07', 3, 1),(6, '小昭', 19, '程 序员鼓励师', 6600, '-10-12', 2, 1);

接下来,我们可以做一个测试,删除id1的部门信息。

结果,我们看到删除成功,而删除成功之后,部门表不存在id1的部门,而在emp表中还有很多的员工,关联的为id1的部门,此时就出现了数据的不完整性。 而要想解决这个问题就得通过数据库的外键约束。

1.3.3 创建外键

创建表时添加外键示例:

说明:外键可以一次性创建多个。

案例: 为emp表的dept_id字段添加外键约束,关联dept表的主键id

alter table empadd constraint fk_emp_dept_id foreign key (dept_id) references dept (id);

添加了外键约束之后,我们再到dept表(父表)删除id1的记录,然后看一下会发生什么现象。 此时将会报错,不能删除或更新父表记录,因为存在外键约束。

1.3.4 删除外键

语法:

ALTER TABLE 表名DROP FOREIGN KEY 外键名称;

案例:删除emp表的外键fk_emp_dept_id

alter table empdrop foreign key fk_emp_dept_id;

1.3.5 外键的 删除 / 更新行为

添加了外键之后,再删除父表数据时产生的约束行为,我们就称为删除/更新行为。具体的删除/更新行为有以下几种:

具体语法为:

ALTER TABLE 表名ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段) REFERENCES 主表名 (主表字段名) ON UPDATE CASCADE ON DELETE CASCADE;

演示如下:

由于NO ACTION是默认行为,我们前面语法演示的时候,已经测试过了,就不再演示了,这里我们再演示其他的两种行为:CASCADESET NULL

CASCADE(级联更新):

alter table empadd constraint fk_emp_dept_id foreign key (dept_id) references dept (id) on update cascade on delete cascade;

修改父表id1的记录,将id修改为6

我们发现,原来在子表中dept_id值为1的记录,现在也变为6了,这就是cascade级联的效果。

在一般的业务系统中,不会修改一张表的主键值

删除父表id6的记录

我们发现,父表的数据删除成功了,但是子表中关联的记录也被级联删除了。

SET NULL

在进行测试之前,我们先需要删除上面建立的外键fk_emp_dept_id。然后再通过数据脚本,将empdept表的数据恢复。

alter table empadd constraint fk_emp_dept_id foreign key (dept_id) references dept (id) on update set null on delete set null;

接下来,我们删除id1的数据,看看会发生什么样的现象。

我们发现父表的记录是可以正常的删除的,父表的数据删除之后,再打开子表emp,我们发现子表empdept_id字段,原来dept_id为1的数据,现在都被置为NULL了。

这就是SET NULL这种删除/更新行为的效果。

1.4 补充:通过图形化界面修改 / 查看外键

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。