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 外键约束,一张表要与另一张表的主键或唯一键进行关联,说明表与表之间的关联关系
相关推荐
m0_598177235 分钟前
SQL 方法函数(1)
数据库
oMcLin6 分钟前
如何在Oracle Linux 8.4上通过配置Oracle RAC集群,确保企业级数据库的高可用性与负载均衡?
linux·数据库·oracle
信创天地6 分钟前
核心系统去 “O” 攻坚:信创数据库迁移的双轨运行与数据一致性保障方案
java·大数据·数据库·金融·架构·政务
胖咕噜的稞达鸭9 分钟前
进程间的通信(1)(理解管道特性,匿名命名管道,进程池,systeam V共享内存是什么及优势)重点理解代码!
linux·运维·服务器·数据库
德彪稳坐倒骑驴13 分钟前
Sqoop入门常用命令
数据库·hadoop·sqoop
资深web全栈开发13 分钟前
pg on delete 策略探讨
数据库·pg
玖日大大14 分钟前
Milvus 深度解析:开源向量数据库的技术架构、实践指南与生态生态
数据库·开源·milvus
雪域迷影17 分钟前
Node.js中使用node-redis库连接redis服务端并存储数据
数据库·redis·node.js
W001hhh37 分钟前
260111
java·数据库
inksci1 小时前
Python 中使用 SQL 连接池
服务器·数据库·python