约束是关系型数据库的一个重要的功能
主要作用是保证数据的完整性,也可以理解为数据的正确性(数据本身是否正确,关联关系是否正常)
约束类型
类型 | 说明 |
---|---|
NOT NULL⾮空约束 | 指定⾮空约束的列不能存储 NULL 值 |
DEFALUT 默认约束 | 当没有给列赋值时使⽤的默认值 |
UNIQUE 唯⼀约束 | 指定唯⼀约束的列每⾏数据必须有唯⼀的值 |
PRIMARY KEY 主键约束 | NOT NULL 和 UNIQUE的结合,可以指定⼀个列或多个列,有助于防⽌数据 重复和提⾼数据的查询性能 |
FOREIGN KEY 外键约束 | 外键约束是⼀种关系约束,⽤于定义两个表之间的关联关系,可以确保数据的完整性和⼀致性 |
CHECK 约束 | ⽤于限制列或数据在数据库表中的值,确保数据的准确性和可靠性 |
注意:
-
UNIQUE 唯⼀约束 的字段NULL可以重复插入
-
PRIMARY KEY 主键约束 的列即使非空也是唯一的
如果设置一个字段非空且唯一(id bigint not null unique)在desc查询表结构的时候会显示id的key为PRI
-
一个表中不允许有两个主键,但一个主键可以包含多个字段(复合主键)
-
FOREIGN KEY 外键约束 表中某个列的值要建立外键关系,这个值必须是另一张表的主键列,或是唯一约束列并且存在。
语法:foregin key (字段名) reference 主表(列);
sqlcreate table student( id bigint PRIMARY KEY auto_increment, name varchar(20) not null, age int DEFAULT 18, class_id bigint, foreign key (class_id) references class(id) # 创建外键约束 );
-
当子表中存在对主表的依赖的时候,不能删除主表中相应的记录,汇报一个主外键关系的错误。如果要删除主表中记录要先删除子表中记录。
-
CHECK 约束可以应⽤于⼀个或多个列,⽤于限制列中可接受的数据值,从⽽确保数据的完整性和准确性。 在8.0.16开始全⾯⽀持CHECK约束,之前的版本会忽略CHECK的定义
sql# 加⼊CHECK约束 create table student( id bigint PRIMARY KEY auto_increment, # 设置⾃增主键 name varchar(20) not null, age int DEFAULT 18, gender char(1), check (age >= 16), check (gender = '男' or gender = '⼥') );
自增类型

可以让数据库来维护主键的增长,在插入的时候先找最大值,然后在这个基础上加1,生成一个新的值,做为一个新数据行的主键的值。
在设置了自增后,也可以指定一个主键值插入,只要不重复即可。
由于主键自增是在最大值的基础上加1,那么主键值在数据表中可能是不连续的。
注意:正常写入数据时,主键自增。如果写入数据的时候,由于某种原因报错了(主外键约束,语法...),也会生成一个主键值,但记录不会成功写入,这个主键值也会被视为已使用。下一次写入数据时,就会发现主键值不连续的现象
总结
- NOT NULL 非空约束,被指定 NOT NULL 的列,值不允许为空(必填)
- UNIQUE 唯一约束,这个列里的值在表中是唯一的,也就是说不能重复
- PRIMARY KEY 主键约束,可以看做是 NOT NULL 和 UNIQUE 的组合,可以用一个 bigint 类型列为表单独指定主键,同时也可以指定主键自增,用 auto_increment 关键字,自增操作时,会找到当前列中最大的值,然后在这个基础上加 1(+1)
- DEFAULT 默认约束,如果写入一行记录的时候,指定了默认约束的列,如果在写入数据时没有指定一个确定的值就会用默认值进行填充该字段的值
- FOREIGN KEY 外键约束,一张表要与另一张表的主键或唯一键进行关联,说明表与表之间的关联关系