MySQL约束超详解
目录
- MySQL约束操作
- 1.非空约束
- 2.唯一约束
- 3.主键约束
- 4.外键约束
- 5、级联
MySQL约束操作 概念:对表中的数据进行限定,保证数据的正确性,有效性和完整性。
分类:
- 主键:
primary key
- 非空约束:
not null
- 唯一约束:
unique
- 外键约束:
foreign key
1.非空约束
创建表时添加非空约束:not null
,值不能为空。
CREATE TABLE stu( id INT, NAME VARCHAR(20) NOT NULL);
【MySQL约束超详解】创建表完后,添加非空约束
ALTER TABLE stu MODIFY NAME VARCHAR(20) NOT NULL;
删除非空约束
ALTER TABLE stu MODIFY NAME VARCHAR(20);
2.唯一约束
创建表时添加唯一约束unique,
值不能重复。
CREATE stu( id INT; phone_number VARCHAR(20) UNIQUE);
注意:删除唯一约束mysql
中,唯一约束限定的列的值可以有多个null
。
ALTER TABLE stuDROP INDEX phone_number;
创建表完后,添加唯一约束
ALTER TABLE stu MODIFY phone_number VARCHAR(20) UNIQUE;
3.主键约束
创建表时添加主键约束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 stuMODIFY id INT; #这样只会删除自动增长,主键删不掉。
创建表完后,在添加自动增长
ALTER TABLE stuMODIFY id INT AUTO_INCREMENT;
4.外键约束
在创建表时,可以添加外键foreign ley
,让表与表产生关系,从而保证数据的正确性。
CREATE TABLE 表名( ... 外键列 CONSTRAINT 外键名称 FOREIGN KEY (外键列名称) REFERENCES 主表名称(主表列名称));
删除外键
ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;
创建表之后,添加外键
ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称);
5、级联
添加级联操作
ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称)ON UPDATE CASCADE ON DELETE CASCADE;
级联删除
ON UPDATE CASCADE
到此这篇关于MySQL约束超详解的文章就介绍到这了,更多相关MySQL约束内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- 为什么你的路演总会超时()
- 标签、语法规范、内联框架、超链接、CSS的编写位置、CSS语法、开发工具、块和内联、常用选择器、后代元素选择器、伪类、伪元素。
- 松软可口易消化,无需烤箱超简单,新手麻麻也能轻松成功~
- 原生家庭之痛与超越
- BNC公链|BNC公链 | Eth2.0测试网Topaz已质押超100万枚ETH
- 89㎡挤出小三房,电视墙装的超好看!
- 真正的爱
- py连接mysql
- 2019-01-18Mysql中主机名的问题
- MySql数据库备份与恢复