外键:
//建立外键
CREATE TABLE TB_NAME(
ID INT,
NAME VARCHAR(20) ,
TEACHER_ID INT,
CONSTRAINT 外键名 FOREIGN KEY (子表字段名) REFERENCES 主表名(主表对应字段名)
);
//删除外键
ALTER TABLE TB_NAME DROP FOREIGN KEY 外键名;
//数据级联:删除(更新)主表数据时,同步删除(更新)字表数据
CONSTRAINT 外键名 FOREIGN KEY (子表字段名) REFERENCES 主表名(主表对应字段名) ON DELETE CASCADE
ON UPDATE CASCADE;
ALTER TABLE TB_NAME ADD CONSIRAINT 外键名 FOREIGN KEY (子表字段名)
REFERENCES 主表名(主表对应字段名) ON DELETE CASCADE ON UPDATE CASCADE;
(1)建立外键时,会自动为该字段建立索引;若该字段之前有索引,则不会再为其建立索引。
(2)删除外键后,该字段的索引仍然存在;外键存在时,不能直接删除该字段索引;
(3)建表后,想将普通外键改为级联外键,需要先drop原来外键;
(4)子表外键的字段必须在主表对应字段范围内;
(5)当主表数据被子表引用时,主表不允许删除,子表对应数据删除后才能删除主表,
但是,当是级联外键时,主表数据允许删除,同时子表对应的数据也被删除;
(6)子表参照的必须是主键列(一表只能有一主键)或唯一列,同一表可以有多个外键。