0
点赞
收藏
分享

微信扫一扫

MySQL7种约束还不懂? 万字整理MySQL约束,哪里不会点哪里

夜空一星 2022-05-03 阅读 47

[](()3、添加非空约束

①建表时

CREATE TABLE 表名称(

字段名 数据类型,

字段名 数据类型 NOT NULL,

字段名 数据类型 NOT NULL

);

**举例: 《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》无偿开源 威信搜索公众号【编程进阶路】 **

CREATE TABLE student(

sid int,

sname varchar(20) not null,

tel char(11) ,

cardid char(18) not null

);

insert into student values(1,‘张三’,‘13710011002’,‘110222198912032545’); #成功

insert into student values(2,‘李四’,‘13710011002’,null);#身份证号为空

#会报:ERROR 1048 (23000): Column ‘cardid’ cannot be null

insert into student values(2,‘李四’,null,‘110222198912032546’);#成功,tel允许为空

insert into student values(3,null,null,‘110222198912032547’);#失败

#会报:ERROR 1048 (23000): Column ‘sname’ cannot be null

②建表后

这个内容是对表结构的修改,想了解更多表结构修改,可以看[MySQL表结构的修改](()

alter table 表名称 modify 字段名 数据类型 not null;

举例:

ALTER TABLE emp

MODIFY sex VARCHAR(2) NOT NULL;

alter table student modify sname varchar(20) not null;

[](()4、删除非空约束

alter table 表名称 modify 字段名 数据类型 NULL;#去掉not null,相当于修改某个非注解字段,该字段允许为空

alter table 表名称 modify 字段名 数据类型;#去掉not null,相当于修改某个非注解字段,该字段允许为空

举例:

ALTER TABLE emp

MODIFY sex VARCHAR(30) NULL;

ALTER TABLE emp

MODIFY NAME VARCHAR(15) DEFAULT ‘abc’ NULL;

[](()❤二、唯一性约束


[](()1、作用

用来限制某个字段/某列的值不能重复

[](()2、特点

  • 同一个表可以有多个唯一约束

  • 唯一约束可以是某一个列的值唯一,也可以多个列组合的值唯一

  • 唯一性约束允许列值为空,并且可以有多个

  • 在创建唯一约束的时候,如果不给唯一约束命名,就默认和列名相同

  • MySQL会给唯一约束的列上默认创建一个唯一索引

[](()3、添加唯一约束

(1)建表时

语法结构:

create table 表名称(

字段名 数据类型,

字段名 数据类型 unique,

字段名 数据类型 unique,

字段名 数据类型

);

create table 表名称(

字段名 数据类型,

字段名 数据类型,

字段名 数据类型,

#这个是表级约束

[constraint 约束名] unique key(字段名)

);

(2)建表后指定唯一键约束

#字段列表中如果是一个字段,表示该列的值唯一。如果是两个或更多个字段,那么复合唯一,即多个字段的组合是唯一的

#方式1:

alter table 表名 add unique key(字段列表);

#方式2:

alter table 表名 modify 字段名 字段类型 unique;

举例:

#这是表级约束

ALTER TABLE USER

ADD UNIQUE(NAME,PASSWORD);

注意: 表级约束中name、password只要有一个不相同就可以了,以实际生活想象:不同的用户可以设置相同的密码。

#‘CONSTRAINT uk_name_pwd’是给约束取名为‘uk_name_pwd’

ALTER TABLE USER

ADD CONSTRAINT uk_name_pwd UNIQUE(NAME,PASSWORD);

查看约束名:

SELECT * FROM information_schema.table_constraints WHERE table_name = ‘表名’; #查看都有哪些约束

在这里插入图片描述

从图片可以看到:如果主动设置唯一约束名,默认是列名

#把name设置为唯一性约束

ALTER TABLE USER

MODIFY NAME VARCHAR(20) UNIQUE;

[](()4、删除唯一约束

  • 添加唯一性约束的列上也会自动创建唯一索引

  • 删除唯一约束只能通过删除唯一索引的方式删除

  • 删除时需要指定唯一索引名,唯一索引名就和唯一约束名一样

  • 如果创建唯一约束时未指定名称,如果是单列,就默认和列名相同;如果是组合列,那么默认和()中排在第一个的列名相同。也可以自定义唯一性约束名

举例:

#删除索引是id的唯一性约束

ALTER TABLE USER

DROP INDEX id;

注意: 可以通过 show index from 表名称;查看表的索引

SHOW INDEX FROM emp;

[](()❤三、PRIMARY KEY 约束


[](()1、作用

用来唯一标识表中的一行记录。

[](()2、特点

  • 主键约束相当于唯一约束+非空约束的组合,主键约束列不允许重复,也不允许出现空值`

  • 一个表最多只能有一个主键约束,建立主键约束可以在列级别创建,也可以在表级别上创建

  • 主键约束对应着表中的一列或者多列(复合主键)

  • 如果是多列组合的复合主键约束,那么这些列都不允许为空值,并且组合的值不允许重复

  • MySQL的主键名总是PRIMARY,就算自己命名了主键约束名也没用

  • 当创建主键约束时,系统默认会在所在的列或列组合上建立对应的主键索引(能够根据主键查询的,就根据主键查询,效率更高)。如果删除主键约束了,主键约束对应的索引就自动删除了

  • 不要修改主键字段的值,因为主键是数据记录的唯一标识,如果修改了主键的值,就有可能会破坏数据的完整性。

[](()3、添加主键约束

(1)建表时指定主键约束

语法结构:

create table 表名称(

字段名 数据类型 primary key, #列级模式

字段名 数据类型

);

create table 表名称(

字段名 数据类型,

字段名 数据类型,

[constraint 约束名] primary key(字段名) #表级模式,[]内设置约束名

);

举例:

#列级约束

create table temp(

id int primary key,

name varchar(20)

);

insert into temp values(1,‘张三’);#成功

insert into temp values(1,‘张三’);#失败

ERROR 1062 (23000): Duplicate(重复) entry(键入,输入) ‘1’ for key ‘PRIMARY’

insert into temp values(1,‘王五’);#失败

ERROR 1062 (23000): Duplicate entry ‘1’ for key ‘PRIMARY’

insert into temp values(4,null);#成功

insert into temp values(null,‘李琦’);#失败

ERROR 1048 (23000): Column ‘id’ cannot be null

#表级约束

CREATE TABLE emp5(

id INT NOT NULL AUTO_INCREMENT,

NAME VARCHAR(20),

pwd VARCHAR(15),

CONSTRAINT emp5_id_pk PRIMARY KEY(id)

);

(2)建表后增加主键约束

ALTER TABLE 表名 ADD PRIMARY KEY(字段列表); #字段列表可以是一个字段,也可以是多个字段,如果是多个字段的话,是复合主键(表级约束)

ALTER TABLE student ADD PRIMARY KEY (sid);

ALTER TABLE emp5 ADD PRIMARY KEY(NAME,pwd);

[](()4、关于复合主键

语法结构:

create table 表名称(

字段名 数据类型,

字段名 数据类型,

字段名 数据类型,

primary key(字段名1,字段名2) #表示字段1和字段2的组合是唯一的,也可以有更多个字段

);

#学生表

create table student(

sid int primary key, #学号

sname varchar(20) #学生姓名

);

#课程表

create table course(

cid int primary key, #课程编号

cname varchar(20) #课程名称

);

#选课表

create table student_course(

sid int,

cid int,

score int,

primary key(sid,cid) #复合主键

);

insert into student values(1,‘张三’),(2,‘李四’);

insert into course values(1001,‘Java’),(1002,‘MySQL’);

insert into student_course values(1, 1001, 89),(1,1002,90),(2,1001,88),(2,1002,56);

上述插入语句都成功,说明其复合主键约束跟复合唯一性约束在功能上差不多。即两个主键约束满足一个就可以

CREATE TABLE emp(

age INT ,

name VARCHAR(25),

id INT UNIQUE ,

#取别名,但是没有用

CONSTRAINT emp_py PRIMARY KEY(age,name)

);

查看结果:

在这里插入图片描述

[](()5、删除主键约束

alter table 表名 drop primary key;

举例:

ALTER TABLE emp DROP PRIMARY KEY;

如下图: 非空依然存在

在这里插入图片描述

[](()❤四、FOREIGN KEY 约束


[](()1、作用

限定某个表的某个字段的引用完整性。

比如:员工表的员工所在部门的选择,必须在部门表能找到对应的部分。

[](()2、主表和从表

主表:被引用的表,被参考的表

从表:引用别人的表,参考别人的表

例如:员工表的员工所在部门这个字段的值要参考部门表:部门表是主表,员工表是从表。

例如:学生表、课程表、选课表:选课表的学生和课程要分别参考学生表和课程表,学生表和课程表是主表,选课表是从表。

[](()3、特点(没事看看)

  • 从表的外键列,必须引用/参考主表的主键或唯一约束的列

  • 在创建外键约束时,如果不给外键约束命名,默认名不是列名,而是自动产生一个外键名

  • 创建(CREATE)表时就指定外键约束的话,先创建主表,再创建从表

  • 删表时,先删从表(或先删除外键约束),再删除主表

  • 当主表的记录被从表参照时,主表的记录将不允许删除,如果要删除数据,需要先删除从表中依赖该记录的数据,然后才可以删除主表的数据

  • 在从表中指定外键约束,并且一个表可以建立多个外键约束

  • 从表的外键列与主表被参照的列名字可以不相同,但是数据类型必须一样,逻辑意义一致

  • 当创建外键约束时,系统默认会在所在的列上建立对应的普通索引。但是索引名是外键的约束名。(根据外键查询效率很高)

  • 删除外键约束后,必须手动删除对应的索引

[](()4、添加外键约束

(1)建表时

create table 主表名称(

字段1 数据类型 primary key,

字段2 数据类型

);

create table 从表名称(

字段1 数据类型 primary key,

字段2 数据类型,

[CONSTRAINT <外键约束名称>] FOREIGN KEY(从表的某个字段) references 主表名(被参考字段)

);

#(从表的某个字段)的数据类型必须与主表名(被参考字段)的数据类型一致,逻辑意义也一样

#(从表的某个字段)的字段名可以与主表名(被参考字段)的字段名一样,也可以不一样

– FOREIGN KEY: 在表级指定子表中的列

– REFERENCES: 标示在父表中的列

create table dept( #主表

did int primary key, #部门编号

dname varchar(50) #部门名称

);

create table emp(#从表

eid int primary key, #员工编号

ename varchar(5), #员工姓名

deptid int, #员工所在的部门

foreign key (deptid) references dept(did) #在从表中指定外键约束

#emp表的deptid和和dept表的did的数据类型一致,意义都是表示部门的编号

);

(2)建表后

语法格式:

ALTER TABLE 从表名 ADD [CONSTRAINT 约束名] FOREIGN KEY (从表的字段) REFERENCES 主表名(被引用字段) [on update xx][on delete xx];

举例:

ALTER TABLE emp1

ADD [CONSTRAINT emp_dept_id_fk] FOREIGN KEY(dept_id) REFERENCES dept(dept_id);

create table dept(

did int primary key, #部门编号

dname varchar(50) #部门名称

);

create table emp(

eid int primary key, #员工编号

ename varchar(5), #员工姓名

deptid int #员工所在的部门

);

#这两个表创建时,没有指定外键的话,那么创建顺序是随意

alter table emp add foreign key (deptid) references dept(did);

[](()5、 约束等级(了解)

  • Cascade方式:在父表上update/delete记录时,同步update/delete掉子表的匹配记录

  • Set null方式:在父表上update/delete记录时,将子表上匹配记录的列设为null,但是要注意子表的外键列不能为not null

  • No action方式:如果子表中有匹配的记录,则不允许对父表对应候选键进行update/delete操作

  • Restrict方式:同no action, 都是立即检查外键约束

  • Set default方式(在可视化工具SQLyog中可能显示空白):父表有变更时,子表将外键列设置成一个默认的值,但Innodb不能识别

如果没有指定等级,就相当于Restrict方式。

对于外键约束,最好是采用: ON UPDATE CASCADE ON DELETE RESTRICT 的方式。

举例: on update cascade on delete cascade

create table dept(

did int primary key,

dname varchar(50)

);

create table emp(

eid int primary key,

ename varchar(5),

deptid int,

foreign key (deptid) references dept(did) on update cascade on delete cascade

#即当删除或修改主表的primary key 对应列的值时,从表中的列数据也会对应删除

);

insert into dept values(1001,‘教学部’);

insert into dept values(1002, ‘财务部’);

insert into dept values(1003, ‘咨询部’);

insert into emp values(1,‘张三’,1001); #在添加这条记录时,要求部门表有1001部门

insert into emp values(2,‘李四’,1001);

insert into emp values(3,‘王五’,1002);

#删除主表的记录成功,主表的1001行被删除了,从表相应的记录也被删除了

delete from dept where did=1001;

如图所示:

在这里插入图片描述

[](()6、删除外键约束

流程如下:

(1)第一步先查看约束名和删除外键约束

SELECT * FROM information_schema.table_constraints WHERE table_name = ‘表名称’;#查看某个表的约束名

ALTER TABLE 从表名 DROP FOREIGN KEY 外键约束名;

(2)第二步查看索引名和删除索引。(注意,只能手动删除)

SHOW INDEX FROM 表名称; #查看某个表的索引名

ALTER TABLE 从表名 DROP INDEX 索引名;

举例:

SELECT * FROM information_schema.table_constraints WHERE table_name = ‘emp’;

ALTER TABLE emp DROP FOREIGN KEY emp_ibfk_1;

SHOW INDEX FROM emp;

举报

相关推荐

0 条评论