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约束最清加最强解析的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程