MySQL约束超详解
作者:LL.LEBRON 时间:2024-01-21 07:10:00
目录
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
);
创建表完后,添加非空约束
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 stu
DROP 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 stu
MODIFY id INT;
#这样只会删除自动增长,主键删不掉。
创建表完后,在添加自动增长
ALTER TABLE stu
MODIFY 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
来源:https://blog.csdn.net/qq_45966440/article/details/119612447
标签:MySQL,约束
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
SQL Server 2016 TempDb里的显著提升
2024-01-24 17:15:47
![](https://img.aspxhome.com/file/2023/4/106224_0s.png)
在NumPy中创建空数组/矩阵的方法
2023-11-02 05:30:35
详解vue项目中调用百度地图API使用方法
2024-05-09 09:38:29
![](https://img.aspxhome.com/file/2023/0/127420_0s.png)
SQL Server中修改“用户自定义表类型”问题的分析与方法
2024-01-24 01:13:58
![](https://img.aspxhome.com/file/2023/9/108529_0s.png)
Python弹出输入框并获取输入值的实例
2021-04-05 00:49:10
CSS背景图片的运用优化HTTP连接数
2008-09-04 21:38:00
![](https://img.aspxhome.com/file/UploadPic/20089/4/200894214417934s.gif)
mysql中的日期相减的天数函数
2024-01-20 01:00:51
Python闭包执行时值的传递方式实例分析
2021-09-22 14:43:50
Python 新建文件夹与复制文件夹内所有内容的方法
2022-03-22 00:05:05
设计原则-控件Balloons(气球状提示)
2009-08-15 12:34:00
![](https://img.aspxhome.com/file/UploadPic/20098/15/balloons-56s.png)
评论是倒序好还是顺序好?
2007-11-09 10:40:00
![](https://img.aspxhome.com/file/UploadPic/200711/9/2007119104745707s.png)
如何防止未经注册的用户绕过注册界面直接进入应用系统?
2009-11-22 19:22:00
mpvue+vant app搭建微信小程序的方法步骤
2024-05-29 22:22:42
关于SQL Server数据库中转储设备分析
2009-01-21 14:55:00
HTML5 的五个激动人心的特性
2009-01-02 17:36:00
![](https://img.aspxhome.com/file/UploadPic/20091/2/html5_1-47s.jpg)
Python搭建代理IP池实现存储IP的方法
2023-04-21 10:58:24
![](https://img.aspxhome.com/file/2023/9/103529_0s.png)
apache配置虚拟主机的方法详解
2023-06-18 09:05:29
几款优秀的中文字体设计
2008-03-24 17:25:00
![](https://img.aspxhome.com/file/UploadPic/20083/24/2008324173030354s.jpg)
Python创建二维数组实例(关于list的一个小坑)
2021-04-29 19:28:13
基于JS+Canvas的lucky-canvas 抽奖功能
2024-04-19 09:51:26
![](https://img.aspxhome.com/file/2023/5/136075_0s.webp)