Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > mysql数据库约束

MySQL不可忽视的数据库约束(维护数据秩序)

作者:学无止尽5

数据库约束是数据库管理中不可或缺的一部分,它们在维护数据秩序、保证数据完整性和一致性方面发挥着重要作用,本文给大家介绍MySQL不可忽视的数据库约束,感兴趣的朋友一起看看吧

引言
在数据库管理的世界里,有一群默默无闻却又至关重要的“幕后英雄”——数据库约束。它们如同忠诚的卫士,时刻守护着数据的完整性和一致性,确保数据库系统的稳定运行。然而,在实际的数据库设计和开发过程中,数据库约束的重要性常常被忽视,导致数据混乱、错误频出。今天,我们就来深入探讨一下数据库约束的奥秘,以及它们在维护数据秩序方面的关键作用。

一、数据库约束的定义和类型

数据库约束是一种规则,用于限制数据库中数据的插入、更新和删除操作,以确保数据的准确性、完整性和一致性。常见的数据库约束类型包括:

类型说明
NOT NULL(不允许为空)指定⾮空约束的列不能存储 NULL 值
DEFAULT(设置默认值)当没有给列赋值时使⽤的默认值
UNIQUE(值需唯一)指定唯⼀约束的列每⾏数据必须有唯⼀的值
PRIMARY KEY(主键,兼具非空和唯一)NOT NULL 和 UNIQUE的结合,可以指定⼀个列或多个列,有助于防⽌数据重复和提⾼数据的查询性能
FOREIGN KEY(建立表间关联)外键约束是⼀种关系约束,⽤于定义两个表之间的关联关系,可以确保数据的完整性和⼀致性
CHECK(检查数据取值)⽤于限制列或数据在数据库表中的值,确保数据的准确性和可靠性

二、数据库约束的分类

2.1⾮空约束(NOT NULL)

定义表时某列不允许为NULL时,可以为列添加⾮空约束。

以创建一个学生表为例,当学生名为null,这条记录就是不完整的。

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

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

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

2.2. DEFALUT 默认值约束

DEFAULT 约束⽤于向列中插⼊默认值,如果没有为列设置值,那么会将默认值设置到该列

重构学⽣表,新增年龄列

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

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

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

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

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

2.3. UNIQUE 唯⼀约束

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

当不设置唯⼀约束时,学号可以重复

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

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

2.4PRIMARY KEY 主键约束

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

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

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

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

其中主键值可以不连续

2.5FOREIGN KEY 外键约束

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

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

2.6CHECK 约束

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

插入正常数据

当插入年龄小于16时

插入的性别不符合实际是

三、数据库约束的作用

四、数据库约束的应用场景

五、数据库约束的注意事项

六、总论

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

到此这篇关于MySQL不可忽视的数据库约束(维护数据秩序)的文章就介绍到这了,更多相关mysql数据库约束内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文