1.外键约束(保持数据一致,完整。实现一对多或一对一)
父表(参照的表)和子表(有外键列的表)必须使用相同的存储引擎InnoDB,禁止使用临时表。
外键列和参照列必须具有相似的数据类型。其中数字的长度或有符号位必须相同,而字符长度可以不同。
外键列和参照列必须创建索引。外键列不存在索引,mysql将自动创建。
CREATE TABLE t6( id SMALLINT UNSIGNED PRIMARY KEY AUTO_INCREMENT, pname VARCHAR(20) NOT NULL );
CREATE TABLE t7( id SMALLINT UNSIGNED PRIMARY KEY AUTO_INCREMENT, username VARCHAR(20) NOT NULL, pid SMALLINT UNSIGNED, FOREIGN KEY(pid) REFERENCES provinces(id) );
可查看索引
SHOW INDEXES FROM t6
1.CASCADE:从父表删除或更新且自动删除或更新子表与之匹配的行
2.SET NULL:从父表删除或更新行,并设置子表中的外键列
3.RESTRICT:拒绝对父表的删除或更新操作
4:NO ACTION:sql关键字,在mysql中与RESTRICT相同
注:一般开发过程中,使用逻辑外键,不使用FOREIGN KEY因为具又局限性。
表级约束与列级约束
对一个数据列建立的约束,称为列级约束
对多个数据列建立的约束,称为表级约束
2.修改数据表,增加字段
ALTER TABLE t7 ADD age TINYINT UNSIGNED NOT NULL DEFAULT 10
删除列
ALTER TABLE t7 DROP age
添加约束
ALTER TABLE user2 ADD id SMALLINT NOT NULL
添加主键约束
ALTER TABLE user2 ADD CONSTRAINT PK_user2_id PRIMARY KEY(pid)
添加唯一约束
ALTER TABLE user2 ADD UNIQUE(username);
添加外键约束
ALTER TABLE user2 ADD FOREIGN KEY (pid) REFERENCES provinces(id);
添加默认约束
ALTER TABLE user2 ALTER age SET DEFAULT 15;
删除约束
ALTER TABLE user2 DROP PRIMARY KEY;
ALTER TABLE user2 DROP INDEX username;
ALTER TABLE user2 DROP FOREIGN KEY user2
修改列定义
ALTER TABLE user2 MODIFY id SMALLINT UNSIGNED NOT NULL;