
引言 在数据库管理的世界里,有一群默默无闻却又至关重要的“幕后英雄”——数据库约束。它们如同忠诚的卫士,时刻守护着数据的完整性和一致性,确保数据库系统的稳定运行。然而,在实际的数据库设计和开发过程中,数据库约束的重要性常常被忽视,导致数据混乱、错误频出。今天,我们就来深入探讨一下数据库约束的奥秘,以及它们在维护数据秩序方面的关键作用。
数据库约束是一种规则,用于限制数据库中数据的插入、更新和删除操作,以确保数据的准确性、完整性和一致性。常见的数据库约束类型包括:
类型 | 说明 |
|---|---|
NOT NULL(不允许为空) | 指定⾮空约束的列不能存储 NULL 值 |
DEFAULT(设置默认值) | 当没有给列赋值时使⽤的默认值 |
UNIQUE(值需唯一) | 指定唯⼀约束的列每⾏数据必须有唯⼀的值 |
PRIMARY KEY(主键,兼具非空和唯一) | NOT NULL 和 UNIQUE的结合,可以指定⼀个列或多个列,有助于防⽌数据重复和提⾼数据的查询性能 |
FOREIGN KEY(建立表间关联) | 外键约束是⼀种关系约束,⽤于定义两个表之间的关联关系,可以确保数据的完整性和⼀致性 |
CHECK(检查数据取值) | ⽤于限制列或数据在数据库表中的值,确保数据的准确性和可靠性 |
定义表时某列不允许为NULL时,可以为列添加⾮空约束。

此时班级名为null,就没有意义了,所以我们要约束学⽣名的列不能为NULL。当name列为空时,他就会报错。

当我们插入包括name时即可插入成功

我们可以查看表结构,NULL列为NO表⽰值不允许为NULL,YES表⽰值可以为NULL

DEFAULT 约束⽤于向列中插⼊默认值,如果没有为列设置值,那么会将默认值设置到该列
重构学⽣表,新增年龄列

插⼊⼀条记录,没有设置默认约束时,不指定年龄的值时列为NULL

重构学⽣表,为年龄的列加⼊默认约束

插⼊⼀条记录,不指定年龄的值时列使⽤了默认值,可以看到使用了默认值18

查看表结构,年龄列的默认值为18

当然当⼿动明确指年龄列为NULL时列值为NULL

指定了唯⼀约束的列,该列的值在所有记录中不能重复,⽐如⼀个⼈的⾝份证号,学⽣的学号等
当不设置唯⼀约束时,学号可以重复

当我们为学号设置列设置唯⼀约束,这时输入相同的学号就会报错

查看表结构,Key列显⽰UNI表⽰唯⼀约束

为ID列添加⾮空和唯⼀约束。 查看表结构,添加了⾮空和唯⼀约束之后Key列显⽰PRI表⽰主键

当Id列的重复时会发⽣主键冲突

通常我们会把主键列设置为⾃动增⻓,让数据库维护主键值和插⼊数据时不设置主键列的值,我们插入第一个数据主键列的值为NULL,第二个数据不指定主键,最终主键列的值会自动生成。

查看表结构时候,Extra列显⽰autoincrement 表⽰⾃增

其中主键值可以不连续

重构学⽣表(从表),加⼊外键约束,在这里创建主表class从表student

查看表结构,Key列的值为MUL表⽰外键约束的列

可以应⽤于⼀个或多个列,⽤于限制列中可接受的数据值,从⽽确保数据的完整性和准确性。 在8.0.16开始全⾯⽀持CHECK约束,之前的版本会忽略CHECK的定义
插入正常数据

当插入年龄小于16时

插入的性别不符合实际是

数据库约束是数据库管理中不可或缺的一部分,它们在维护数据秩序、保证数据完整性和一致性方面发挥着重要作用。作为数据库开发者和管理者,我们应该充分认识到数据库约束的重要性,合理使用约束,确保数据库系统的稳定运行。同时,我们还应该定期对数据库约束进行检查和维护,以适应业务的发展和数据的变化。只有这样,我们才能真正发挥数据库约束的作用,为企业的信息化建设提供有力支持。