数据表的约束简介

为防止错误的数据被插入到数据表,MySQL中定义了一些维护数据库完整性的规则;这些规则常称为表的约束。常见约束如下:

约束条件

说明

PRIMARY KEY

主键约束用于唯一标识对应的记录

FOREIGN KEY

外键约束

NOT NULL

非空约束

UNIQUE

唯一性约束

DEFAULT

默认值约束,用于设置字段的默认值

以上五种约束条件针对表中字段进行限制从而保证数据表中数据的正确性和唯一性。换句话说,表的约束实际上就是表中数据的限制条件

主键约束

主键约束即primary key用于唯一的标识表中的每一行。被标识为主键的数据在表中是唯一的且其值不能为空。这点类似于我们每个人都有一个身份证号,并且这个身份证号是唯一的。

字段名 数据类型 primary key;

设置主键约束(primary key)的第一种方式

create table student(
    id int primary key,
    name varchar(20)
);

设置主键约束(primary key)的第二种方式

create table student01(
    id int
    name varchar(20),
    primary key(id)
);

非空约束

非空约束即 NOT NULL指的是字段的值不能为空,基本的语法格式如下所示

字段名 数据类型 NOT NULL;
create table student02(
    id int
    name varchar(20) not null
);

默认值约束

默认值约束即DEFAULT用于给数据表中的字段指定默认值,即当在表中插入一条新记录时若未给该字段赋值,那么,数据库系统会自动为这个字段插人默认值;其基本的语法格式如下所示

字段名 数据类型 DEFAULT 默认值;
create table student03(
    id int,
    name varchar(20),
    gender varchar(10) default 'male'
);

唯一性约束

唯一性约束即UNIQUE用于保证数据表中字段的唯一性,即表中字段的值不能重复出现,其基本的语法格式如下所示

字段名 数据类型 UNIQUE;
create table student04(
    id int,
    name varchar(20) unique
);

外键约束

外键约束即FOREIGN KEY常用于多张表之间的约束。基本语法如下:

-- 在创建数据表时语法如下:
CONSTRAINT 外键名 FOREIGN KEY (从表外键字段) REFERENCES 主表 (主键字段)
-- 将创建数据表创好后语法如下:
ALTER TABLE 从表名 ADD CONSTRAINT 外键名 FOREIGN KEY (从表外键字段) REFERENCES 主表 (主键字段);

创建一个学生表 MySQL命令

create table student05(
    id int primary key,
    name varchar(20)
);

创建一个班级表 MySQL命令

create table class(
    classid int primary key,
    studentid int
);

学生表作为主表,班级表作为副表设置外键, MySQL命令

alter table class add constraint fk_class_studentid foreign key(studentid) references student05(id);

数据一致性概念

大家知道:建立外键是为了保证数据的完整和统一性。

但是,如果主表中的数据被删除或修改从表中对应的数据该怎么办呢?

很明显,从表中对应的数据也应该被删除,否则数据库中会存在很多无意义的垃圾数据。

删除外键

alter table 从表名 drop foreign key 外键名;

删除外键 MySQL命令

alter table class drop foreign key fk_class_studentid;

关于外键约束需要注意的细节

  1. 从表里的外键通常为主表的主键
  2. 从表里外键的数据类型必须与主表中主键的数据类型一致
  3. 主表发生变化时应注意主表与从表的数据一致性问题