mysql约束最清加最强解析
2021/10/6 2:11:20
本文主要是介绍mysql约束最清加最强解析,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
目录
一.概述
1.约束概念:
2.分类:
二. 非空约束(not null,某一列的值不能为null)
1. 创建表时添加约束
2. 创建表完后,添加非空约束
3. 删除name的非空约束
三 . 唯一约束(unique,某一列的值不能重复)
1. 注意:
2. 在创建表时,添加唯一约束
3. 删除唯一约束
4. 在表创建完后,添加唯一约束
三 . 主键约束(primary key)
2. 在创建表时,添加主键约束
3. 删除主键
4. 创建完表后,添加主键
四. 自动增长
1. 概念
2.建表并添加自动约束
3. 删除自动增长
4. 添加自动增长
五 . 外键约束(foreign key)
1.概念
2. 在创建表时,可以添加外键
3. 删除外键
4. 创建表之后,添加外键
六 . 级联操作
1. 添加级联操作
2. 分类
3.总结:
一.概述
1.约束概念:
约束:对表中的数据进行限定,保证数据的正确性、有效性和完整性。
2.分类:
a. 主键约束:primary key
b. 非空约束:not null
c. 唯一约束:unique
d. 外键约束:foreign key
二. 非空约束(not null,某一列的值不能为null)
1. 创建表时添加约束
-- 创建一个名字不能为空值的学生表
-- 创建一个名字不能为空值的学生表 CREATE TABLE student( id INT, NAME VARCHAR(10) NOT NULL -- name为非空 );
2. 创建表完后,添加非空约束
ALTER TABLE student MODIFY NAME VARCHAR(10) NOT NULL;
3. 删除name的非空约束
ALTER TABLE student MODIFY NAME VARCHAR(10);
三 . 唯一约束(unique,某一列的值不能重复)
1. 注意:
唯一约束可以有NULL值,但是只能有一条记录为null
2. 在创建表时,添加唯一约束
-- 创建一个电话号码不能重复的学生表 CREATE TABLE student( id INT, phone_number VARCHAR(11) UNIQUE -- 手机号 );
3. 删除唯一约束
ALTER TABLE student DROP INDEX phone_number;
4. 在表创建完后,添加唯一约束
ALTER TABLE student MODIFY phone_number VARCHAR(11) UNIQUE;
三 . 主键约束(primary key)
1. 注意:
a. 含义:非空且唯一
b. 一张表只能有一个字段为主键
c. 主键就是表中记录的唯一标识
2. 在创建表时,添加主键约束
-- 创建一个id为主键的学生表 create table student( id int primary key,-- 给id添加主键约束 name varchar(10) );
3. 删除主键
ALTER TABLE student DROP PRIMARY KEY;
4. 创建完表后,添加主键
ALTER TABLE student MODIFY id INT PRIMARY KEY;
四. 自动增长
1. 概念
自动增长:如果某一列是数值类型的,使用 auto_increment 可以来完成值得自动增长
2.建表并添加自动约束
-- 创建一张学生表,添加主键约束,并且完成主键自增长 create table student( id int primary key auto_increment,-- 给id添加主键约束 name varchar(10) );
3. 删除自动增长
ALTER TABLE student MODIFY id INT;
4. 添加自动增长
ALTER TABLE student MODIFY id INT AUTO_INCREMENT;
五 . 外键约束(foreign key)
1.概念
外键约束:让表于表产生关系,从而保证数据的正确性。
2. 在创建表时,可以添加外键
-- 语法: create table 表名( .... 外键列 constraint 外键名称 foreign key (外键列名称) references 主表名称(主表列名称) );
3. 删除外键
ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;
4. 创建表之后,添加外键
ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称);
六 . 级联操作
1. 添加级联操作
-- 语法: ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称) ON UPDATE CASCADE ON DELETE CASCADE ;
2. 分类
a. 级联更新:ON UPDATE CASCADE
-- 语法: ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称) ON UPDATE CASCADE;
b. 级联删除:ON DELETE CASCADE
-- 语法: ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称)
3.总结:
联级操作的好处:方便对多表数据库进行统一操作,方便快捷
联级操作的弊端:会误删其他表相级联的全部数据和历史记录,在实际开发中对级联的操作要谨慎使用,思考清楚再使用。
这篇关于mysql约束最清加最强解析的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-02MySQL集群项目实战:新手入门指南
- 2024-11-02初学者指南:部署MySQL集群资料
- 2024-11-01部署MySQL集群教程:新手入门指南
- 2024-11-01如何部署MySQL集群:新手入门教程
- 2024-11-01部署MySQL集群学习:新手入门教程
- 2024-11-01部署MySQL集群入门:新手必读指南
- 2024-10-23BinLog入门:新手必读的MySQL二进制日志指南
- 2024-10-23Binlog入门:MySQL数据库的日志管理指南
- 2024-10-22MySQL数据库入门教程:从安装到基本操作
- 2024-10-22MySQL读写分离入门教程:轻松实现数据库性能提升