MySQL约束超详解


Posted in MySQL onSeptember 04, 2021

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

到此这篇关于MySQL约束超详解的文章就介绍到这了,更多相关MySQL约束内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

MySQL 相关文章推荐
详解MySQL数据库千万级数据查询和存储
May 18 MySQL
MySQL中distinct和count(*)的使用方法比较
May 26 MySQL
MYSQL(电话号码,身份证)数据脱敏的实现
May 28 MySQL
浅谈MySQL之浅入深出页原理
Jun 23 MySQL
Mysql外键约束的创建与删除的使用
Mar 03 MySQL
MySQL如何快速创建800w条测试数据表
Mar 17 MySQL
MySQL Server层四个日志的实现
Mar 31 MySQL
mysql 索引的数据结构为什么要采用B+树
Apr 26 MySQL
MySQL批量更新不同表中的数据
May 11 MySQL
MySQL详细讲解变量variables的用法
Jun 21 MySQL
MySQL常用慢查询分析工具详解
Aug 14 MySQL
mysql通过group by分组取最大时间对应数据的两种有效方法
Sep 23 MySQL
MySQL中的隐藏列的具体查看
Sep 04 #MySQL
Mysql实现简易版搜索引擎的示例代码
Aug 30 #MySQL
详细聊聊MySQL中慢SQL优化的方向
Aug 30 #MySQL
MySQL8.0的WITH查询详情
Aug 30 #MySQL
Prometheus 监控MySQL使用grafana展示
Aug 30 #MySQL
MySQL命令无法输入中文问题的解决方式
Aug 30 #MySQL
mysql 索引合并的使用
Aug 30 #MySQL
You might like
php小偷相关截取函数备忘
2010/11/28 PHP
php打印一个边长为N的实心和空心菱型的方法
2015/03/02 PHP
php使用glob函数遍历文件和目录详解
2016/09/23 PHP
详解阿里云视频直播PHP-SDK接入教程
2020/07/09 PHP
Js动态创建div
2008/09/25 Javascript
JS 密码强度验证(兼容IE,火狐,谷歌)
2010/03/15 Javascript
同一页面多个商品倒计时JS 基于面向对象的javascript
2012/02/16 Javascript
Yii-自定义删除确认弹框(zyd)jquery实现代码
2013/03/04 Javascript
JS实现随机数生成算法示例代码
2013/08/08 Javascript
简单常用的幻灯片播放实现代码
2013/09/25 Javascript
SyntaxHighlighter 3.0.83使用笔记
2015/01/26 Javascript
PHP+MySQL+jQuery随意拖动层并即时保存拖动位置实例讲解
2015/10/09 Javascript
JavaScript实现瀑布流布局
2020/06/28 Javascript
使用JS实现图片展示瀑布流效果(简单实例)
2016/09/06 Javascript
webpack vue项目开发环境局域网访问方法
2018/03/20 Javascript
简单明了区分escape、encodeURI和encodeURIComponent
2018/05/26 Javascript
一百行JS代码实现一个校验工具
2019/04/30 Javascript
JS对象属性的检测与获取操作实例分析
2020/03/17 Javascript
vue 通过绑定事件获取当前行的id操作
2020/07/27 Javascript
Python生成随机MAC地址
2015/03/10 Python
python 使用re.search()筛选后 选取部分结果的方法
2018/11/28 Python
Python使用sqlalchemy模块连接数据库操作示例
2019/03/13 Python
PyQt5 QListWidget选择多项并返回的实例
2019/06/17 Python
python 设置输出图像的像素大小方法
2019/07/04 Python
Linux下升级安装python3.8并配置pip及yum的教程
2020/01/02 Python
Python如何存储数据到json文件
2020/03/09 Python
keras中的loss、optimizer、metrics用法
2020/06/15 Python
纯CSS3实现手风琴风格菜单具体步骤
2013/05/06 HTML / CSS
THE OUTNET英国官网:国际设计师品牌折扣网站
2016/08/14 全球购物
linux面试题参考答案(1)
2016/01/22 面试题
师范生实习的个人自我鉴定
2013/10/20 职场文书
教育学专业实习生的自我鉴定
2013/11/26 职场文书
宣传部部长竞选演讲稿
2014/04/26 职场文书
财务管理专业自荐书
2014/09/02 职场文书
2015入党自荐书范文
2015/03/05 职场文书
利用JuiceFS使MySQL 备份验证性能提升 10 倍
2022/03/17 MySQL