MySQL表的约束详解

本文详细介绍了MySQL中的四种约束:主键(PRIMARY KEY)、外键(FOREIGN KEY)、唯一约束(UNIQUE)和检查约束(CHECK)。主键确保表中每一行都有唯一标识,外键用于建立表间关联,唯一约束保证字段值的唯一性,而检查约束则用于验证字段值的有效性。创建、修改和删除这些约束的方法也在文中进行了讲解。
摘要由CSDN通过智能技术生成

目录

一、MySQL主键(PRIMARY KEY)

创建表时设置主键约束

创建表时设置联合主键

删除主键约束、修改主键约束

 二、MySQL外键约束(FOREIGN KEY)及唯一约束(UNIQUE)

在创建表时设置外键约束及唯一约束

三、MySQL检查约束(CHECK)

删除检查约束

 四、MySQL查看表中的约束


一、MySQL主键(PRIMARY KEY)

主键(PRIMARY KEY)的完整称呼是“主键约束”,是 MySQL 中使用最为频繁的约束。一般情况下,为了便于 DBMS 更快的查找到表中的记录,都会在表中设置一个主键。

使用主键应注意以下几点:

  • 每个表只能定义一个主键。
  • 主键值必须唯一标识表中的每一行,且不能为 NULL,即表中不可能存在有相同主键值的两行数据。这是唯一性原则。
  • 一个字段名只能在联合主键字段表中出现一次。
  • 联合主键不能包含不必要的多余字段。当把联合主键的某一字段删除后,如果剩下的字段构成的主键仍然满足唯一性原则,那么这个联合主键是不正确的。这是最小化原则。

创建表时设置主键约束

在 CREATE TABLE 语句中,通过 PRIMARY KEY 关键字来指定主键。

create table tt1(
id int(10),
sex enum('男','女')DEFAULT'男',
teacher VARCHAR(5),
PRIMARY KEY(teacher)
);
insert into tt1 (id,teacher)VALUE(202201,'Lucy');
-- 因为主键是teacher 具有唯一性 所以插入不成功
-- insert into tt1 (id,teacher)VALUE(202202,'Lucy');
SELECT * FROM tt1;

创建表时设置联合主键

所谓的联合主键,就是这个主键是由一张表中多个字段组成的。
比如,设置学生选课数据表时,使用学生编号做主键还是用课程编号做主键呢?如果用学生编号做主键,那么一个学生就只能选择一门课程。如果用课程编号做主键,那么一门课程只能有一个学生来选。显然,这两种情况都是不符合实际情况的。
实际上设计学生选课表,要限定的是一个学生只能选择同一课程一次。因此,学生编号和课程编号可以放在一起共同作为主键,这也就是联合主键了。

注意:当主键是由多个字段组成时,不能直接在字段名后面声明主键约束。

create table tt2(
id int(10),
sex enum('男','女')DEFAULT'男',
teacher VARCHAR(5),
PRIMARY KEY(id,teacher)
);
insert into tt2 (id,teach
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值