整理的笔记,方便后续查看复习用
推荐书籍 《SQL必知必会》
约束
- 概念:约束是作用于表中字段上的规则,用于限制储存在表中的数据
- 目的:保证数据库中数据的正确性、有效性和完整性
- 分类:
约束 描述 关键字 非空约束 限制该字段的数据不能为null NOT NULL 唯一约束 保证该字段的所有数据都是唯一、不重复的 UNIQUE 主键约束 主键是一行数据的唯一标识,要求非空且唯一 PRIMARY KEY 默认约束 保存数据时,如果未指定该字段的值,则采用默认值 DEFAULT 检查约束 保证字段值满足某一个条件 CHECK 外键约束 用于让两张表的数据之间建立连接,保证数据的一致性和完整性 FOREIGN KEY
外键约束
概念:用于让两张表的数据之间建立连接,保证数据的一致性和完整性
语法:
- 添加外键:
- 在创建表时直接添加:
[CONSTRAINT] [外键名称] FOREIGN KEY(外键字段名) REFERENCES 主表(主表列名)
- 单独添加:
ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY(外键字段名) REFERENCES 主表(主表列名);
删除外键
ALTER TABLE 表名 DROP FOREIGN KEY 外键名称;
删除/更新行为
行为 说明 NO ACTION 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新(默认行为)(与RESTRICT一致) RESTRICT 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有则不允许删除/更新(默认行为)(与NO ACTION一致) CASCADE 当在父表中删除/更新对应记录时,首先检查该记录是否有对应外键,如果有,则也删除/更新外键在子表中的记录(级联) SET NULL 当在父表中删除对应记录时,首先检查该记录是否有对应外键,如果有则设置子表中该外键值为null(要求该外键允许取null) SET DEFAULT 当父表有变更时,子表将外键列设置成一个默认的值
ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY(外键字段名) REFERENCES 主表(主表列名) ON UPDATE CASCADE ON DELETE CASCADE;