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基础(二)
Apr 05 MySQL
Mysql - 常用函数 每天积极向上
Apr 05 MySQL
MySQL Shell的介绍以及安装
Apr 24 MySQL
MySQL Router实现MySQL的读写分离的方法
May 27 MySQL
探究Mysql模糊查询是否区分大小写
Jun 11 MySQL
Mysql8.0递归查询的简单用法示例
Aug 04 MySQL
MySQL 数据类型详情
Nov 11 MySQL
解决MySQL添加新用户-ERROR 1045 (28000)的问题
Mar 03 MySQL
浅谈如何保证Mysql主从一致
Mar 13 MySQL
mysql insert 存在即不插入语法说明
Mar 25 MySQL
MySQL8.0 Undo Tablespace管理详解
Jun 16 MySQL
MySQL深分页问题解决思路
Dec 24 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 GD绘制24小时柱状图
2008/06/28 PHP
PHP define函数的使用说明
2008/08/27 PHP
JavaScript中“过于”犀利地for/in循环使用示例
2013/10/22 Javascript
关闭ie窗口清除Session的解决方法
2014/01/10 Javascript
Javascript 按位取反运算符 (~)
2014/02/04 Javascript
情人节单身的我是如何在敲完代码之后收到12束玫瑰的(javascript)
2015/08/21 Javascript
jquery validate demo 基础
2015/10/29 Javascript
javascript实现label标签跳出循环操作
2016/03/06 Javascript
获取JS中网页各种高宽与位置的方法总结
2016/07/27 Javascript
JS重载实现方法分析
2016/12/16 Javascript
JS实现iframe自适应高度的方法示例
2017/01/07 Javascript
微信小程序页面滑动屏幕加载数据效果
2020/11/16 Javascript
详解angular如何调用HTML字符串的方法
2018/06/30 Javascript
vue项目中添加单元测试的方法
2018/07/21 Javascript
VUE DOM加载后执行自定义事件的方法
2018/09/07 Javascript
Vue循环组件加validate多表单验证的实例
2018/09/18 Javascript
详解基于node.js的脚手架工具开发经历
2019/01/28 Javascript
javascript实现简易数码时钟
2020/03/30 Javascript
谈一谈vue请求数据放在created好还是mounted里好
2020/07/27 Javascript
Openlayers实现测量功能
2020/09/25 Javascript
让python json encode datetime类型
2010/12/28 Python
详细讲解Python中的文件I/O操作
2015/05/24 Python
Tensorflow环境搭建的方法步骤
2018/02/07 Python
浅谈Tensorflow由于版本问题出现的几种错误及解决方法
2018/06/13 Python
解决pyinstaller打包pyqt5的问题
2019/01/08 Python
python中hasattr()、getattr()、setattr()函数的使用
2019/08/16 Python
python接口调用已训练好的caffe模型测试分类方法
2019/08/26 Python
python手机号前7位归属地爬虫代码实例
2020/03/31 Python
tensorflow从ckpt和从.pb文件读取变量的值方式
2020/05/26 Python
Helly Hansen工作服美国官方网上商店:为最恶劣的环境
2019/09/04 全球购物
教师岗位职责范本
2013/12/29 职场文书
求职简历自我评价范例
2014/03/12 职场文书
习近平在党的群众路线教育实践活动总结大会上的讲话
2014/10/21 职场文书
2015年扶贫帮困工作总结
2015/05/20 职场文书
领导莅临指导欢迎词
2015/09/30 职场文书
2016寒假假期总结
2015/10/10 职场文书