目录Mysql约束操作1.非空约束 2.唯一约束3.主键约束4.外键约束5、级联mysql约束操作 概念:对表中的数据进行限定,保证数据的正确性,有效性和完整性。 分类:
概念:对表中的数据进行限定,保证数据的正确性,有效性和完整性。
分类:
primary key
not null
unique
foreign key
not null
,值不能为空。
创建表时添加非空约束:
CREATE TABLE stu(
id INT,
NAME VARCHAR(20) NOT NULL
);
创建表完后,添加非空约束
ALTER TABLE stu
MODIFY NAME VARCHAR(20) NOT NULL;
删除非空约束
ALTER TABLE stu
MODIFY NAME VARCHAR(20);
unique,
值不能重复。
创建表时添加唯一约束
CREATE stu(
id INT;
phone_number VARCHAR(20) UNIQUE
);
注意:
mysql
中,唯一约束限定的列的值可以有多个null
。
删除唯一约束
ALTER TABLE stu
DROP INDEX phone_number;
创建表完后,添加唯一约束
ALTER TABLE stu
MODIFY phone_number VARCHAR(20) UNIQUE;
primary key,
- 非空且唯一。
- 一张表只能有一个字段为主键。
- 主键就是表中记录的唯一标识。
创建表时添加主键约束
CREATE TABLE stu(
id INT PRIMARY KEY,
NAME VARCHAR(20)
);
删除主键
ALTER TABLE stu
DROP PRIMARY KEY;
创建表完后,添加主键
ALTER TABLE stu
MODIFY id INT PRIMARY KEY ;
这里补充一个知识点:自动增长
概念:如果某一列是数值类型的,使用auto_increment
可以来完成自动增长。
例子:
在创建表时,添加主键约束,并且完成主键自动增长
CREATE TABLE stu(
id INT PRIMARY KEY AUTO_INCREMENT,
NAME VARCHAR(20)
);
#自动增长会根据当前列的最后一行的值往后增加。
删除自动增长
ALTER TABLE stu
MODIFY id INT;
#这样只会删除自动增长,主键删不掉。
创建表完后,在添加自动增长
ALTER TABLE stu
MODIFY id INT AUTO_INCREMENT;
foreign ley
,让表与表产生关系,从而保证数据的正确性。
在创建表时,可以添加外键
CREATE TABLE 表名(
...
外键列
CONSTRaiNT 外键名称 FOREIGN KEY (外键列名称) REFERENCES 主表名称(主表列名称)
);
删除外键
ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;
创建表之后,添加外键
ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称);
添加级联操作
ALTER TABLE 表名 ADD CONSTRAINT 外键名称
FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称)
ON UPDATE CASCADE ON DELETE CASCADE ;
级联删除
ON UPDATE CASCADE
到此这篇关于MySQL约束超详解的文章就介绍到这了,更多相关MySQL约束内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: MySQL约束超详解
本文链接: https://lsjlt.com/news/134466.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-10-23
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0