MySQL(3)—— 约束

本文主要讨论数据库中的约束。

约束是关系数据库的一个重要功能;数据库中的约束是表中数据的限制条件,用于保证数据的完整性和一致性。

约束类型

  • NOT NULL:指示某列不能存储NULL值
  • UNIQUE:保证某列的每行必须有唯一的值
  • DEFAULT:规定没有给列赋值时的默认值
  • PRIMARY KEY:确保某列有唯一标识,有助于更容易更快速地找到表中的一个特定的记录
  • FOREIGN KEY:保证一个表中的数据匹配另一个表中的值的参照完整性
  • CHECK:保证列中的值符合指定的条件。

NOT NULL

在前面建表的时候,我们可以看到表的属性中有NULL这一个字段;当没有指定非空约束时,当前的列是可以写入一个NULL值的;如果要把某一列定义为一个必填项,就可以使用NOT NULL约束。比如:

如果要使用该约束,需要在创建表时进行设定:

sql 复制代码
create table student (
    id bigint not null,
    name varchar(50)
);

查看一下student表:

所以此处在输入数据时,id字段不能输入NULL值,MySQL会做一次非空校验。


UNIQUE

保证某列的每行必须有唯一的值,意思就是该列的值在整个表中不能重复。

创建一个在id字段进行唯一约束的表。


DEFAULT

表示在输入数据时默认插入的数据;不规定时默认为空。可以通过Default来规定写入时的默认值。这里就不做演示。


PRIMARY KEY

表示++主键约束++。主键约束既是非空的也是唯一的。把表中的某一列设置为非空且唯一,那么该字段就是该表的主键。

【主键】一张表的每行数据都需要至少一个不能重复、不能为空的标识;该标识对应的字段就是主键。一张表只能有一个主键。一个表中不允许出现两个主键,但可以同时包含多个列(复合主键)

一般在每个表建立时使用如上命名来设定主键。其中auto_increment表示自增。该命令可以让数据库帮我们去维护主键的增长,不用我们自己去运算;在插入的时候先找到最大值,然后在该值的基础上加1,生成一个新的值来作为新数据行的主键的值。

而也有复合主键的情况,即以两列的数据来判断非空和唯一,写法如下:


FOREIGN KEY

类似于上面的主键,foreign key用于设置外键

【外键】在一张表中引入另一张表的主键,这个引入的主键就是外键。

外键的存在可以建立两张表之间的联系。外键的书写如下:

sql 复制代码
foreign key (字段名)references 主表(列)

CHECK

直接用一个例子理解:

该代码用于在插入数据时确保 gender 字段输入的是 "男"或者"女";

可以看到,当输入其他数据时会报错,并且不会存入数据库中。

相关推荐
瀚高PG实验室1 天前
审计策略修改
网络·数据库·瀚高数据库
言慢行善1 天前
sqlserver模糊查询问题
java·数据库·sqlserver
韶博雅1 天前
emcc24ai
开发语言·数据库·python
有想法的py工程师1 天前
PostgreSQL 分区表排序优化:Append Sort 优化为 Merge Append
大数据·数据库·postgresql
喵了几个咪1 天前
如何在 Superset Docker 容器中安装 MySQL 驱动
mysql·docker·容器·superset
迷枫7121 天前
达梦数据库的体系架构
数据库·oracle·架构
夜晚打字声1 天前
9(九)Jmeter如何连接数据库
数据库·jmeter·oracle
Chasing__Dreams1 天前
Mysql--基础知识点--95--为什么避免使用长事务
数据库·mysql
NineData1 天前
NineData 智能数据管理平台新功能发布|2026 年 3 月
数据库·oracle·架构·dba·ninedata·数据复制·数据迁移工具
小陈工1 天前
2026年4月7日技术资讯洞察:下一代数据库融合、AI基础设施竞赛与异步编程实战
开发语言·前端·数据库·人工智能·python