各位用户为了找寻关于MySQL约束超详解的资料费劲了很多周折。这里教程网为您整理了关于MySQL约束超详解的相关资料,仅供查阅,以下为您介绍关于MySQL约束超详解的详细内容
MySQL约束操作
概念:对表中的数据进行限定,保证数据的正确性,有效性和完整性。
分类:
主键:primary key
非空约束:not null
唯一约束:unique
外键约束:foreign key
1.非空约束
not null
,值不能为空。
创建表时添加非空约束:
? 1 2 3 4CREATE
TABLE
stu(
id
INT
,
NAME
VARCHAR
(20)
NOT
NULL
);
创建表完后,添加非空约束
? 1 2ALTER
TABLE
stu
MODIFY
NAME
VARCHAR
(20)
NOT
NULL
;
删除非空约束
? 1 2ALTER
TABLE
stu
MODIFY
NAME
VARCHAR
(20);
2.唯一约束
unique,
值不能重复。
创建表时添加唯一约束
? 1 2 3 4CREATE
stu(
id
INT
;
phone_number
VARCHAR
(20)
UNIQUE
);
注意:mysql
中,唯一约束限定的列的值可以有多个null
。
删除唯一约束
? 1 2ALTER
TABLE
stu
DROP
INDEX
phone_number;
创建表完后,添加唯一约束
? 1 2ALTER
TABLE
stu
MODIFY
phone_number
VARCHAR
(20)
UNIQUE
;
3.主键约束
primary key,
创建表时添加主键约束
? 1 2 3 4CREATE
TABLE
stu(
id
INT
PRIMARY
KEY
,
NAME
VARCHAR
(20)
);
删除主键
? 1 2ALTER
TABLE
stu
DROP
PRIMARY
KEY
;
创建表完后,添加主键
? 1 2ALTER
TABLE
stu
MODIFY
id
INT
PRIMARY
KEY
;
这里补充一个知识点:自动增长
概念:如果某一列是数值类型的,使用auto_increment
可以来完成自动增长。
例子:
在创建表时,添加主键约束,并且完成主键自动增长
? 1 2 3 4 5CREATE
TABLE
stu(
id
INT
PRIMARY
KEY
AUTO_INCREMENT,
NAME
VARCHAR
(20)
);
#自动增长会根据当前列的最后一行的值往后增加。
删除自动增长
? 1 2 3ALTER
TABLE
stu
MODIFY
id
INT
;
#这样只会删除自动增长,主键删不掉。
创建表完后,在添加自动增长
? 1 2ALTER
TABLE
stu
MODIFY
id
INT
AUTO_INCREMENT;
4.外键约束
foreign ley
,让表与表产生关系,从而保证数据的正确性。
在创建表时,可以添加外键
? 1 2 3 4 5CREATE
TABLE
表名(
...
外键列
CONSTRAINT
外键名称
FOREIGN
KEY
(外键列名称)
REFERENCES
主表名称(主表列名称)
);
删除外键
? 1ALTER
TABLE
表名
DROP
FOREIGN
KEY
外键名称;
创建表之后,添加外键
? 1ALTER
TABLE
表名
ADD
CONSTRAINT
外键名称
FOREIGN
KEY
(外键字段名称)
REFERENCES
主表名称(主表列名称);
5、级联
添加级联操作
? 1 2 3ALTER
TABLE
表名
ADD
CONSTRAINT
外键名称
FOREIGN
KEY
(外键字段名称)
REFERENCES
主表名称(主表列名称)
ON
UPDATE
CASCADE
ON
DELETE
CASCADE
;
级联删除
? 1ON
UPDATE
CASCADE
到此这篇关于MySQL约束超详解的文章就介绍到这了,更多相关MySQL约束内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
原文链接:https://blog.csdn.net/qq_45966440/article/details/119612447