MySQL中的约束详解

约束是关系型数据库的一个重要的功能

主要作用是保证数据的完整性,也可以理解为数据的正确性(数据本身是否正确,关联关系是否正常)

约束类型

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

注意:

  1. UNIQUE 唯⼀约束 的字段NULL可以重复插入

  2. PRIMARY KEY 主键约束 的列即使非空也是唯一的

    如果设置一个字段非空且唯一(id bigint not null unique)在desc查询表结构的时候会显示id的key为PRI

  3. 一个表中不允许有两个主键,但一个主键可以包含多个字段(复合主键)

  4. FOREIGN KEY 外键约束 表中某个列的值要建立外键关系,这个值必须是另一张表的主键列,或是唯一约束列并且存在。

    语法:foregin key (字段名) reference 主表(列);

    sql 复制代码
    create 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) # 创建外键约束
    );
  5. 当子表中存在对主表的依赖的时候,不能删除主表中相应的记录,汇报一个主外键关系的错误。如果要删除主表中记录要先删除子表中记录。

  6. 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,那么主键值在数据表中可能是不连续的。

注意:正常写入数据时,主键自增。如果写入数据的时候,由于某种原因报错了(主外键约束,语法...),也会生成一个主键值,但记录不会成功写入,这个主键值也会被视为已使用。下一次写入数据时,就会发现主键值不连续的现象

总结

  1. NOT NULL 非空约束,被指定 NOT NULL 的列,值不允许为空(必填)
  2. UNIQUE 唯一约束,这个列里的值在表中是唯一的,也就是说不能重复
  3. PRIMARY KEY 主键约束,可以看做是 NOT NULL 和 UNIQUE 的组合,可以用一个 bigint 类型列为表单独指定主键,同时也可以指定主键自增,用 auto_increment 关键字,自增操作时,会找到当前列中最大的值,然后在这个基础上加 1(+1)
  4. DEFAULT 默认约束,如果写入一行记录的时候,指定了默认约束的列,如果在写入数据时没有指定一个确定的值就会用默认值进行填充该字段的值
  5. FOREIGN KEY 外键约束,一张表要与另一张表的主键或唯一键进行关联,说明表与表之间的关联关系
相关推荐
全栈老石4 小时前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
倔强的石头_1 天前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北2 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12024 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号35 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏5 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker