MySQL入门第三天——数据表的约束

数据表的约束简介

为防止错误的数据被插入到数据表,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. 主表发生变化时应注意主表与从表的数据一致性问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

傅里叶级数ff

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值