龙空技术网

全程软件测试(七十七):数据表的约束—读书笔记

阳哥做IT笔记 174

前言:

现在大家对“删除数据表中字段的唯一约束”大约比较关切,大家都想要剖析一些“删除数据表中字段的唯一约束”的相关文章。那么小编同时在网摘上汇集了一些关于“删除数据表中字段的唯一约束””的相关文章,希望各位老铁们能喜欢,我们一起来学习一下吧!

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

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

1.主键约束

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

主键约束基本语法:

字段名 数据类型 primary key;
设置主键约束(primary key)的第一种方式

示例:MySQL命令:

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

运行效果展示:

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

示例:MySQL命令:

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

运行效果展示:

2.非空约束

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

字段名 数据类型 NOT NULL;

示例:MySQL命令:

create table student02(id intname varchar(20) not null);

运行效果展示:

3.默认值约束

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

字段名 数据类型 DEFAULT 默认值;

示例:MySQL命令:

create table student03(id int,name varchar(20),gender varchar(10) default 'male');

运行效果展示:

5.唯一性约束

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

字段名 数据类型 UNIQUE;

示例:MySQL命令:

create table student04(id int,name varchar(20) unique);

运行效果展示:

6.外键约束

外键约束即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);

运行效果展示:

6.1 数据一致性概念

大家知道:建立外键是为了保证数据的完整和统一性。但是,如果主表中的数据被删除或修改从表中对应的数据该怎么办呢?很明显,从表中对应的数据也应该被删除,否则数据库中会存在很多无意义的垃圾数据。

6.2 删除外键

语法如下:

alter table 从表名 drop foreign key 外键名;
示例:删除外键 MySQL命令:
alter table class drop foreign key fk_class_studentid;

运行效果展示:

外键的那个字段不在了证明删除成功了

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

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

标签: #删除数据表中字段的唯一约束