常见的几种约束

 

约束描述关键字
非空约束限制该字段的数据不能为nullnot null
唯一约束保证该字段的所有数据都是唯一、不重复的unique
主键约束主键是一行数据的唯一标识,要求非空且唯一primary key
默认约束保存数据时,如果未指定该字段的值,则采用默认值default
检查约束保证字段值满足某一个条件check
外键约束用来让两张表的数据之间建立连接,保证数据的一致性和完整性foreing key

 

 

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

 

字段名字段含义字段类型约束条件约束关键字
idid唯一标识int主键,并且自动增长primar key,auto_increment
name姓名varchar(10)不为空,并且唯一not null,unique
age年龄int大于0,并且小于等于120check
status状态char(1) 如果没有指定该值,默认为1default
gender性别char(1)

 

-- 并且自动增长的意思是该字段的数据不用我们写,由数据库根据数据量自动补充该字段

create database if not exists bilibili; #创建数据库bilibili use bilibili; #选择bilibili数据库,即可进行下面的代码演示 drop database if exists bilibili; #代码演示结束后删除bilibili数据库。这个小文件全部代码演示完再删 show databases; #查看是否删除完成

 

-- 创建案例所需的用户表

 

-- 验证,插入数据即可验证

 

-- 查看user表

 

-- 删除user表

 

 

外键约束

 

-- 准备两张表

 

-- 添加外键为fk_tmp_dept_id,tmp表的dept_id字段(这个字段同时也是我们设置的外键)去关联dept表的主键id -- 首先学习如何添加外键,我们要在创建表的时候给该表添加外键,如下

 

fk_tmp_dept_id是自定义的外键名

tmp表添加外键之后,这个外键是dept_ip字段,该字段前面的图标多了一个蓝色的钥匙

 

验证:

去dept表,删除id为1的一行,删除研发部,会发现报错,原因:当字表(tmp)外键关联了父表之后,就不能删除父表

 

如何删除外键

 

例如删除上面创建的外键

 

验证:

去dept表,删除id为1的一行,删除研发部,不会报错

 

 

外键删除和更新行为

 

行为说明
no action当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新,与restrict一致
restrict当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新,与no action一致
cascade当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有,则也删除/更新外键在子表中的记录
set null当在父表中删除对应记录时,首先检查该记录是否有对应外键,如果有则设置子表中该外键值为null,前提是该外键允许取null
set default父表有变更时,子表将外键列设置成一个默认的值,注意Innodb引擎是不支持的

 

-- 我们可以在创建外键的时候来指定删除以及更新的行为(行为也叫规则)

 

-- 语法,例如要设cascade行为

 

-- 首先我们要删除上面创建的外键

 

-- 重新创建外键,在创建外键时指定外键删除和更新行为,例如该外键添加cascade行为

 

-- 验证如下 -- 打开父表dept,双击dept表的id字段的第一行,把原先的1改为6,点击上方绿色向上箭头表示确认修改,然后点击tmp表,会 -- 发现外键字段dept_id的第2至6行的数据全部变成了6。即我们修改了父表,子表的相关数据会同步变化 -- 如果我们直接把父表的6研发部删掉,那么子表的第2至6行的数据就会全部消失删掉

 

-- 我们还可以演示一下set null行为。由于我们上面删过dept表的第一行数据,所以我们把dept表、tmp表删了重新创建一次

 

-- 然后再创建dept表,并加上数据,代码在上面的58行 -- 重新给tmp表创建外键来关联dept表,给该外键添加set null行为

 

-- 验证如下 -- 打开父表的dept,删除父表的第一行数据,点击上方绿色向上箭头表示确认修改,然后点击tmp表,会 -- 发现外键字段dept_id的第2至6行的数据全部变成了null

 

-- 注意update后面的更新规则 和 delete后面的删除规则不一定要一样,可以不一样