文章目录
约束
约束介绍和分类
约束的概念:
约束是作用于表中列上的规则,用于限制加入表的数据
约束的存在保证了数据库中数据的正确性、有效性和完整性
约束的分类如下:
约束名称描述关键字非空约束保证列中所有数据不能有null值NOT NULL唯一约束保证列中所有数据各不相同UNIQUE主键约束主键是一行数据的唯一标识, 要求非空且唯一PRIMARY KEY检查约束保证列中的值满足某一条件CHECK默认约束保存数据时, 未指定值则采用默认值DEFAULT外检约束外键用来让两个表的数据之间建立连接, 保证数据的一致性和完整性FOREING KEY
注意: MySQL不支持检查约束
非空约束
概念: 非空约束用于保证列中所有数据不能有NULL值
语法:
添加约束:
-- 创建表时添加非空约束CREATETABLE 表名(
列名 数据类型 NOTNULL,
…
);-- 建完表后添加非空约束ALTERTABLE 表名 MODIFY 字段名 数据类型 NOTNULL;
删除约束:
ALTERTABLE 表名 MODIFY 字段名 数据类型;
唯一约束
概念: 唯一约束用于保证列中所有数据各不相同
语法:
添加约束:
-- 创建表时添加唯一约束CREATETABLE 表名(
列名 数据类型 UNIQUE[AUTO_INCREMENT],-- AUTO_INCREMENT: 当不指定值时自动增长
…
);CREATETABLE 表名(
列名 数据类型,
…
[CONSTRAINT][约束名称]UNIQUE(列名));-- 建完表后添加唯一约束ALTERTABLE 表名 MODIFY 字段名 数据类型 UNIQUE;
删除约束
ALTERTABLE 表名 DROPINDEX 字段名;
主键约束
概念:
主键是一行数据的唯一标识,要求非空且唯一
一张表只能有一个主键
语法:
添加约束: AUTO_INCREMENT表示主键自增
-- 创建表时添加主键约束CREATETABLE 表名(
列名 数据类型 PRIMARYKEY[AUTO_INCREMENT],
…
);CREATETABLE 表名(
列名 数据类型,[CONSTRAINT][约束名称]PRIMARYKEY(列名));-- 建完表后添加主键约束ALTERTABLE 表名 ADDPRIMARYKEY(字段名);
删除约束:
ALTERTABLE 表名 DROPPRIMARYKEY;
默认约束
概念: 保存数据时,未指定值则采用默认值
语法:
添加约束:
-- 创建表时添加默认约束CREATETABLE 表名(
列名 数据类型 DEFAULT 默认值,
…
);-- 建完表后添加默认约束ALTERTABLE 表名 ALTER 列名 SETDEFAULT 默认值;
删除约束:
ALTERTABLE 表名 ALTER 列名 DROPDEFAULT;
案例练习
按照下面图片中的要求, 为表添加合适的约束:
语句演示:
CREATETABLE emp (
id INTPRIMARYKEYAUTO_INCREMENT,
ename VARCHAR(50)NOTNULLUNIQUE,
joindate DATENOTNULL,
salary DOUBLE(7,2)NOTNULL,
bonus DOUBLE(7,2)DEFAULT0);
外键约束
概念: 外键用来让两个表的数据之间建立链接,保证数据的一致性和完整性
语法:
添加约束:
-- 创建表时添加外键约束CREATETABLE 表名(
列名 数据类型,
…
[CONSTRAINT][外键名称]FOREIGNKEY(外键列名)REFERENCES 主表(主表列名));-- 建完表后添加外键约束ALTERTABLE 表名 ADDCONSTRAINT 外键名称 FOREIGNKEY(外键字段名称)REFERENCES 主表名称(主表列名称);
删除约束:
ALTERTABLE 表名 DROPFOREIGNKEY 外键名称;
案例练习
例如我们有如下两张表, 员工表和部门表, 在没有添加外键约束的时候, 是可以直接删除部门表的研发部的;但是我们知道这是不合理的, 因为员工表中, 前三个员工是属于研发部的, 在有员工属于研发部的情况下应该不能删除才合理;
我们可以通过外键约束解决这个问题, 将两张表建立连接: 添加外键, emp表的dep_id关联dept表的id主键;
创建部门表(注意要先创建部门表), 将id设置为主键, 并添加两个部门
-- 部门表CREATETABLE dept(
id INTPRIMARYKEYAUTO_INCREMENT,
dep_name varchar(20),
addr varchar(20));-- 添加两个部门INSERTINTO dept(dep_name, addr)VALUES('研发部','广州'),('销售部','深圳');
创建员工表添加员工, 并为员工表emp添加外键约束
-- 员工表 CREATETABLE emp(
id INTPRIMARYKEYAUTO_INCREMENT,
name VARCHAR(20),
age INT,
dep_id INT,-- 添加外键 dep_id,关联 dept 表的id主键CONSTRAINT fk_emp_dept FOREIGNKEY(dep_id)REFERENCES dept(id));-- 添加员工,dep_id 表示员工所在的部门INSERTINTO emp (NAME, age, dep_id)VALUES('张三',20,1),('李四',20,1),('王五',20,1),('赵六',20,2),('孙七',22,2),('周八',18,2);
不需要可以删除外键
-- 删除外键ALTERTABLE emp DROPFOREIGNKEY fk_emp_dept;
建表后, 也是可以继续添加外键的
-- 添加外键ALTERTABLE emp ADDCONSTRAINT fk_emp_dept FOREIGNKEY(dep_id)REFERENCES dept(id);
版权归原作者 学全栈的灌汤包 所有, 如有侵权,请联系我们删除。