目录
一.概述
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.总结:
约束:对表中的数据进行限定,保证数据的正确性、有效性和完整性。
a. 主键约束:primary key
b. 非空约束:not null
c. 唯一约束:unique
d. 外键约束:foreign key
-- 创建一个名字不能为空值的学生表
-- 创建一个名字不能为空值的学生表 CREATE TABLE student( id INT, NAME VARCHAR(10) NOT NULL -- name为非空 );
ALTER TABLE student MODIFY NAME VARCHAR(10) NOT NULL;
ALTER TABLE student MODIFY NAME VARCHAR(10);
唯一约束可以有NULL值,但是只能有一条记录为null
-- 创建一个电话号码不能重复的学生表 CREATE TABLE student( id INT, phone_number VARCHAR(11) UNIQUE -- 手机号 );
ALTER TABLE student DROP INDEX phone_number;
ALTER TABLE student MODIFY phone_number VARCHAR(11) UNIQUE;
1. 注意:
a. 含义:非空且唯一
b. 一张表只能有一个字段为主键
c. 主键就是表中记录的唯一标识
-- 创建一个id为主键的学生表 create table student( id int primary key,-- 给id添加主键约束 name varchar(10) );
ALTER TABLE student DROP PRIMARY KEY;
ALTER TABLE student MODIFY id INT PRIMARY KEY;
自动增长:如果某一列是数值类型的,使用 auto_increment 可以来完成值得自动增长
-- 创建一张学生表,添加主键约束,并且完成主键自增长 create table student( id int primary key auto_increment,-- 给id添加主键约束 name varchar(10) );
ALTER TABLE student MODIFY id INT;
ALTER TABLE student MODIFY id INT AUTO_INCREMENT;
外键约束:让表于表产生关系,从而保证数据的正确性。
-- 语法: create table 表名( .... 外键列 constraint 外键名称 foreign key (外键列名称) references 主表名称(主表列名称) );
ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;
ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称);
-- 语法: ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段名称) REFERENCES 主表名称(主表列名称) ON UPDATE CASCADE ON DELETE CASCADE ;
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 主表名称(主表列名称)
联级操作的好处:方便对多表数据库进行统一操作,方便快捷
联级操作的弊端:会误删其他表相级联的全部数据和历史记录,在实际开发中对级联的操作要谨慎使用,思考清楚再使用。