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

 更新时间:2025年05月15日 14:55:10   作者:学无止尽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 主键约束

  • 主键约束唯⼀标识数据库表中的每条记录。
  • 主键必须包含唯⼀的值,且不能包含 NULL 值。
  • 每个表只能有⼀个主键,可以由单个列或多个列组成。
  • 通常为每张表都指定⼀个主键,主键列建议使⽤BIGINT类型

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

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

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

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

其中主键值可以不连续

2.5FOREIGN KEY 外键约束

  • 外键⽤于定义主表和从表之间的关系
  • 外键约束主定义在从表的列上,主表关联的列必须是主键或唯⼀约束
  • 当定义外键后,要求从表中的外键列数据必须在主表的主键或唯⼀列存在或为null。

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

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

2.6CHECK 约束

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

插入正常数据

当插入年龄小于16时

插入的性别不符合实际是

三、数据库约束的作用

  • 保证数据的完整性:通过主键约束、唯一约束和外键约束,可以确保表中的数据是唯一的、不重复的,并且与其他表中的数据保持一致。
  • 提高数据的质量:检查约束可以限制列的取值范围,避免无效数据的插入,从而提高数据的质量。
  • 简化数据操作:默认约束可以为列提供默认值,减少数据输入的工作量,提高数据操作的效率。
  • 维护数据库的稳定性:数据库约束可以防止数据的不一致性和错误,从而维护数据库的稳定性和可靠性。

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

  • 订单管理系统:在订单管理系统中,订单表和客户表之间可以通过外键约束建立关联关系,确保订单数据与客户数据的一致性。
  • 学生信息管理系统:在学生信息管理系统中,学生表中的学号列可以设置为主键约束,确保每个学生的学号是唯一的。
  • 商品库存管理系统:在商品库存管理系统中,商品表中的库存数量列可以设置为检查约束,确保库存数量不能为负数。

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

  • 合理使用约束:在设计数据库时,应根据实际需求合理使用约束,避免过度约束或约束不足。
  • 考虑性能影响:数据库约束会对数据库的性能产生一定的影响,应在保证数据完整性的前提下,尽量减少约束的使用。
  • 定期维护约束:随着业务的发展和数据的变化,数据库约束可能需要进行调整和维护,以确保其有效性和适用性。

六、总论

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

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

相关文章

  • Mysql 8 新特性 window functions 的作用

    Mysql 8 新特性 window functions 的作用

    MySQL是众多网站技术栈中的标准配置,是广受欢迎的开源数据库,已经推出了8.0的第一个候选发行版本。接下来通过本文给大家分享Mysql 8 新特性 window functions 的作用,需要的朋友参考下吧
    2017-11-11
  • MySQL8.0中的窗口函数的示例代码

    MySQL8.0中的窗口函数的示例代码

    本文主要介绍了MySQL8.0中的窗口函数的示例代码,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • Linux mysql命令安装允许远程连接的安装设置方法

    Linux mysql命令安装允许远程连接的安装设置方法

    对大家推荐很好使用的Linux mysql系统,像让大家对Linux mysql系统有所了解,然后对Linux mysql系统全面讲解介绍,希望对大家有用今天特意配置了mysql apache php ,虽然网上很多这方面的例子,但是很多是作者再回忆写的,所以难免有笔误的地方。
    2010-08-08
  • Mysql如何查看表及字段信息

    Mysql如何查看表及字段信息

    这篇文章主要介绍了Mysql如何查看表及字段信息,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01
  • 巧用mysql提示符prompt清晰管理数据库的方法

    巧用mysql提示符prompt清晰管理数据库的方法

    随着管理mysql服务器越来越多,同样的mysql>的提示符有可能会让你输入错误的命令到错误的数据库,这时候需要巧用mysql的提示符,这是我的提示符root@localhost(mysql) 08:55:21> 用prompt命令实现(适用于windows和linux环境)
    2009-08-08
  • ubuntu下mysql版本升级到5.7

    ubuntu下mysql版本升级到5.7

    这篇文章主要为大家详细介绍了ubuntu下mysql版本升级到5.7的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • Mysql中的sql优化实践详解

    Mysql中的sql优化实践详解

    这篇文章主要介绍了Mysql中的sql优化实践详解,SQL优化是指通过改进SQL语句的编写和查询计划的设计来提高数据库查询性能的过程,在优化SQL时,可以采取一些措施来提升查询性能,需要的朋友可以参考下
    2023-09-09
  • MySQL数据库主从复制延时超长的解决方法

    MySQL数据库主从复制延时超长的解决方法

    这篇文章主要给大家介绍了关于MySQL数据库主从复制延时超长的解决方法,文中通过示例代码介绍的非常详细,对大家学习或者使用MySQL具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-06-06
  • MySQL8.0中你必须要知道的索引新特性

    MySQL8.0中你必须要知道的索引新特性

    MySQL8.0索引新特性,支持降序索引,降序索引以降序存储键值,下面这篇文章主要给大家介绍了关于MySQL8.0中你必须要知道的索引新特性的相关资料,需要的朋友可以参考下
    2022-11-11
  • Mysql数据库中子查询的使用

    Mysql数据库中子查询的使用

    本文给大家分享mysql数据库中子查询的使用,非常不错具有参考借鉴价值,感兴趣的朋友一起看看吧
    2016-10-10

最新评论