【数据库约束】
文章目录
- 一、什么是数据库约束
- 二、约束类型
- 三、NOT NULL ⾮空约束
- 四、DEFALUT 默认值约束
- 五、UNIQUE 唯⼀约束
- 六、PRIMARY KEY 主键约束
- 七、FOREIGN KEY 外键约束
- 八、CHECK 约束
一、什么是数据库约束
数据库约束是指对数据库表中的数据所施加的规则或条件,⽤于确保数据的准确性和可靠性。这些约束可以是基于数据类型、值范围、唯⼀性、⾮空等规则,以确保数据的正确性和相容性
二、约束类型
三、NOT NULL ⾮空约束
定义表时某列不允许为NULL时,可以为列添加⾮空约束。
⽐如创建⼀个学⽣表,学⽣名为NULL时,这条记录是不完整的
(1)创建表
(2)插入数据
(3)查询,班级名为NULL,没有意义
此时需要约束学⽣名的列不能为NULL
(1)添加not null
(2)由于name列有⾮空约束,插⼊NULL值时报错
(3)正常值可以成功插⼊
查看表结构,NULL列为NO表⽰值不允许为NULL,YES表⽰值可以为NULL
四、DEFALUT 默认值约束
DEFAULT 约束⽤于向列中插⼊默认值,如果没有为列设置值,那么会将默认值设置到该列
- 重构学⽣表,新增年龄列
- 插⼊⼀条记录,没有设置默认约束时,不指定年龄的值时列为NULL
(1)年龄值为NULL
- 重构学⽣表,为年龄的列加⼊默认约束
- 插⼊⼀条记录,不指定年龄的值时列使⽤了默认值
- 查看表结构,年龄列的默认值为18
- 当⼿动明确指年龄列为NULL时列值为NULL
五、UNIQUE 唯⼀约束
指定了唯⼀约束的列,该列的值在所有记录中不能重复,⽐如⼀个⼈的⾝份证号,学⽣的学号等
- 重构学⽣表,新增学号列
- 不设置唯⼀约束时,学号可以重复
- 重构学⽣表,为学号列设置唯⼀约束
- 插⼊重复的学号时报错,唯⼀约束⽣效
- 查看表结构,Key列显⽰UNI表⽰唯⼀约束
注意:只加了唯一约束的列可以写入多个NULL值
六、PRIMARY KEY 主键约束
主键约束唯⼀标识数据库表中的每条记录。(数据库管理数据时,使用主键列作为数据行的“身份证编号”)
主键必须包含唯⼀的值,且不能包含 NULL 值。(非空约束+唯一约束)
每个表只能有⼀个主键,可以由单个列或多个列组成。(复合主键)
通常为每张表都指定⼀个主键,主键列建议使⽤BIGINT类型(范围足够的大,不会溢出)
- 重构学⽣表,为ID列添加⾮空和唯⼀约束
- 查看表结构,添加了⾮空和唯⼀约束之后Key列显⽰PRI表⽰主键
- 当Id列的重复时会发⽣主键冲突
- 通常把主键列设置为⾃动增⻓,让数据库维护主键值
- 插⼊数据时不设置主键列的值
(1)主键列的值为NULL
(2)不指定主键
(3)主键列的值⾃动⽣成
- 查看表结构,Extra列显⽰auto_increment 表⽰⾃增
- 如果某条记录写⼊失败,新⽣成的主键值将会作废
(1)由于学号重复,产⽣了唯⼀冲突,导致插⼊失败,ID为3的主键值作废
(2)修改学号后成功插⼊数据
(3)查询后发现新记录ID列的值为4
show create table student;
- 主键值可以不连续
(1)⼿动指定⼀个值
(2)下⼀次⾃增从主键的最⼤值开始,ID列的值是101
- 主键或唯⼀键冲突时的更新操作,插⼊否则更新
(1)语法
(2)插⼊ID为100,学号为100100的学⽣记录时,报主键冲突
(3)可以使⽤以上语法,如果插⼊时有冲突则更新当前列的值
(4)两⾏受影响,表⽰删除了原来的记录,⼜新写⼊了⼀条记录
(5)与update student set name = ‘赵六’, sno = ‘100100’ where id = 100; 等效
- 替换,如果存在冲突则替换,不存在冲突则插⼊
(1)语法
(2)写⼊或更新Id为101的记录
(3)原数据已更新
(4)写⼊⼀条新数据
(5)成功写⼊
- 表中不能有多个主键
- 复合主键:由多个列共同组成的主键,主键是否冲突以多个列的组成进⾏判定
(1)重构学⽣表,指定复合主键
(2)插⼊数据
(3)重复插⼊主键冲突,此时主键值由id和name两个列共同决定
(4)修改id值插⼊成功
七、FOREIGN KEY 外键约束
外键⽤于定义主表和从表之间的关系
外键约束主定义在从表的列上,主表关联的列必须是主键或唯⼀约束
当定义外键后,要求从表中的外键列数据必须在主表的主键或唯⼀列存在或为null。
- 创建班级表(主表),并初始化数据
(1)建表
(2)初始化数据
- 重构学⽣表(从表),加⼊外键约束
(1)语法
(2)重构表
- 查看表结构,Key列的值为MUL表⽰外键约束的列
- 正常插⼊数据
(1)班级编号在主表中存在
(2)插⼊成功
- 插⼊⼀个班级号为100的学⽣,由于主表中没有这个班级,插⼊失败
(1)班级编号在主表中不存在,提⽰外键约束限制导致插⼊失败
- 插⼊班级Id为NULL的记录,可以成功,表⽰当前学⽣还没有分配置班级
(1)班级为NULL
- 删除主表某条记录时,从表中不能有对该记录的引⽤
(1)删除从表中没有引⽤的记录,可以成功
(2)删除从表中引⽤的记录,失败
- 删除主表时要先删除从表
(1)从表存在是不能删除主表
(2)删除从表
(3)再删除主表,成功
八、CHECK 约束
对单行数据进行校验
可以应⽤于⼀个或多个列,⽤于限制列中可接受的数据值,从⽽确保数据的完整性和准确性。在8.0.16开始全⾯⽀持CHECK约束,之前的版本会忽略CHECK的定义
- 重构学⽣表,有以下要求,年龄不能⼩于16岁,性别只能是男或⼥
(1)加⼊CHECK约束
(2)正常插⼊数据
(3)插⼊年龄⼩于16岁的记录,失败
(4)插⼊性别的值不是男或⼥的记录,失败
- 创建新表,c1的值不能为0,c2的值必须⼤于0,c3的值不⼩于c2
(1)列与列之间也可以⽐较,需要在单独⼀⾏中定义
(2)插⼊正常数据
(3)c1 = 0时,失败
(4)c2 <= 0时,失败
(5)c3 < c2时,失败
以上是本篇文章的全部内容,如果文章有错误或者有看不懂的地方,多和喵博主交流。互相学习互相进步。如果这篇文章对你有帮助,可以给喵博主一个关注,你们的支持是我最大的动力。