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 外键约束,一张表要与另一张表的主键或唯一键进行关联,说明表与表之间的关联关系
相关推荐
yumgpkpm4 小时前
CMP (类ClouderaCDP7.3(404次编译) )华为鲲鹏Aarch64(ARM)信创环境 查询2100w行 hive 查询策略
数据库·数据仓库·hive·hadoop·flink·mapreduce·big data
web安全工具库6 小时前
Makefile 模式规则精讲:从 %.o: %.c 到静态模式规则的终极自动化
linux·运维·c语言·开发语言·数据库·自动化
'需尽欢'6 小时前
基于 Flask+Vue+MySQL的研学网站
python·mysql·flask
清静诗意7 小时前
Ubuntu 系统下 MySQL 8.0 安装与远程访问完整教程
mysql·ubuntu·adb
盒马coding13 小时前
第19节-非规范化数据类型-Composite-types
数据库·postgresql
-雷阵雨-13 小时前
MySQL——桥梁JDBC
数据库·mysql·oracle
亿坊电商13 小时前
在PHP框架里如何进行数据库连接?
数据库·oracle·php