一. 约束
什么是约束呢?约束就是对数据的制约和限定条件,各位小伙伴下面跟着健哥的思路走,思考下面问题:
问题:在往已创建表中新增数据时,可不可以新增两行相同列值得数据?
如果可行,会有什么弊端?
数据重复了,那么肯定会白白浪费服务器的存储空间。所以就一定需要对数据进行限制和约束,设定数据填写的限制条件。
主键约束
PRIMARY KEY 唯一,标识表中的一行数据,此列的值不可重复,且不能为 NULL。
#1.为表中适用主键的列添加主键约束。
CREATE TABLE subject(
subjectId INT PRIMARY KEY, #课程编号标识每一个课程的编号唯一,且不能为 NULL。
subjectName VARCHAR(20),
subjectHours INT
)charset=utf8;
#2.这一条数据会正确插入。
INSERT INTO subject(subjectId,subjectName,subjectHours) VALUES(1,'Java',40);
#3.error主键1已存在,所以插入报错。
INSERT INTO subject(subjectId,subjectName,subjectHours) VALUES(1,'Java',40);
唯一约束
UNIQUE 唯一,标识表中的一行数据,不可重复,可以为 NULL。
#1.为表中列值不允许重复的列添加唯一约束。
CREATE TABLE subject(
subjectId INT PRIMARY KEY,
subjectName VARCHAR(20) UNIQUE, #课程名称唯一。
subjectHours INT
)charset=utf8;
#2.此条数据会正确插入。
INSERT INTO subject(subjectId,subjectName,subjectHours) VALUES(1,'Java',40);
#3.error课程名称已存在,违反唯一约束。
INSERT INTO subject(subjectId,subjectName,subjectHours) VALUES(2,'Java',40);
自动增长列
AUTO_INCREMENT 自动增长,给主键数值列添加自动增长。从1开始,每次加1。不能单独使用,和主键配合。
#1.为表中主键列添加自动增长,避免忘记主键ID序号。
CREATE TABLE subject(
subjectId INT PRIMARY KEY AUTO_INCREMENT,#课程编号主键且自动增长,会从 1 开始根据添加数据的顺序依次加 1
subjectName VARCHAR(20) UNIQUE,
subjectHours INT
)charset=utf8;
#2.课程编号自动从1增长。
INSERT INTO subject(subjectName,subjectHours) VALUES('Java',40);
#3.第二条编号为2。
INSERT INTO subject(subjectName,subjectHours) VALUES('JavaScript',30);
非空约束
NOT NULL 非空,此列必须有值。
#1.课程名称虽然添加了唯一约束,但是有 NULL 值存在的可能,要避免课程名称为 NULL。
CREATE TABLE subject(
subjectId INT PRIMARY KEY AUTO_INCREMENT,
subjectName VARCHAR(20) UNIQUE NOT NULL,
subjectHours INT
)charset=utf8;
#2.error课程名称约束了非空。
INSERT INTO subject(subjectName,subjectHours) VALUES(NULL,40);
默认值约束
DEFAULT 值为列赋予默认值,当新增数据不指定值时,书写DEFAULT,以指定的默认值进行填充。
#1.当存储课程信息时,若课程时长没有指定值,则以默认课时 20 填充。
CREATE TABLE subject(
subjectId INT PRIMARY KEY AUTO_INCREMENT,
subjectName VARCHAR(20) UNIQUE NOT NULL,
subjectHours INT DEFAULT 20
)charset=utf8;
#2.课程时长以默认值 20 填充。
INSERT INTO subject(subjectName,subjectHours) VALUES('Java',DEFAULT);
引用完整性约束
这个引用完整性约束健哥解释一下哈。 指的是数据的一致性和正确性。完整性约束是指数据库的内容必须随时遵守的规则。若定义了数据完整性约束,MySQL会负责数据的完整性,每次更新数据时,MySQL都会测试新的数据内容是否符合相关的完整性约束条件,只有符合完整性的约束条件的更新才被接受。
语法:CONSTRAINT 引用名 FOREIGN KEY(列名) REFERENCES 被引用表名(列名)
详解:FOREIGN KEY 引用外部表的某个列的值,新增数据时,约束此列的值必须是引用表中存在的值。
#1.创建专业表。
CREATE TABLE Speciality(
id INT PRIMARY KEY AUTO_INCREMENT,
SpecialName VARCHAR(20) UNIQUE NOT NULL
)CHARSET=utf8;
#2.创建课程表(课程表的SpecialId 引用专业表的 id)。
CREATE TABLE subject(
subjectId INT PRIMARY KEY AUTO_INCREMENT,
subjectName VARCHAR(20) UNIQUE NOT NULL,
subjectHours INT DEFAULT 20,
specialId INT NOT NULL,
#3.引用专业表里的 id 作为外键,新增课程信息时,约束课程所属的专业。
CONSTRAINT fk_subject_specialId FOREIGN KEY(specialId) REFERENCES Speciality(id)
)charset=utf8;
#4.专业表新增数据。
INSERT INTO Speciality(SpecialName) VALUES('Java');
INSERT INTO Speciality(SpecialName) VALUES('C#');
#5.课程信息表添加数据
#专业 id 为 1,引用的是专业表的 Java。
INSERT INTO subject(subjectName,subjectHours) VALUES('Java',30,1);
#专业 id 为 2,引用的是专业表的 C#。
INSERT INTO subject(subjectName,subjectHours) VALUES('C#MVC',10,2);
相关文章
07.13抢座
06.15抢座
06.29抢座
06.15抢座
06.29抢座
06.29抢座
06.15抢座
06.29抢座
06.29抢座
06.15抢座
了解千锋动态
关注千锋教育服务号
扫一扫快速进入
千锋移动端页面
扫码匿名提建议
直达CEO信箱