目录
mysql外键约束
注:student是从表,class是主表. 在从表中添加外键约束
在从表中添加主表的主键
从表使用 on delete cascade
可以在主表删除相关的数据时,把从表相关数据也删除
准备工作
创建表
sqlcreate table student ( id INT PRIMARY KEY AUTO_INCREMENT, student_name VARCHAR(30), student_sex char(1), student_info VARCHAR(500), student_class_id int ); CREATE table class ( class_id INT PRIMARY KEY AUTO_INCREMENT, class_name VARCHAR(20) );
插入数据
sql-- 插入正常数据 INSERT into student VALUES (null, '偷走晚霞的人', '男', '一个学生', 1), (null, '惜.己', '男', '一个学生', 2), (null, '小玖', '女', '一个学生', 1), (null, '张三', '男', '一个学生', 3), (null, '莉莉', '男', '一个学生', 1), (null, '雪夜', '男', '一个学生', 2), (null, '小明', '女', '一个学生', 1), (null, '小新', '男', '一个学生', 3) ;
创建表时添加外键
1..格式
CONSTRAN 外键约束的名字 FOREIGN KEY (外键字段名) REFERENCES 主表(主键字段)
2..创建表student表时,为其添加外键
sqlDROP TABLE student; -- 创建student表示为 student_class_id 添加 主表的主键 的约束 create table student ( id INT PRIMARY KEY AUTO_INCREMENT, student_name VARCHAR(30), student_sex char(1), student_info VARCHAR(500), student_class_id int , -- 添加主键约束 CONSTRAINT student_class_fk FOREIGN KEY(student_class_id) REFERENCES class(class_id) );
3.插入数据测试
正常数据
sql-- 插入正常数据 INSERT into student VALUES (null, '偷走晚霞的人', '男', '一个学生', 1), (null, '惜.己', '男', '一个学生', 2), (null, '小玖', '女', '一个学生', 1), (null, '张三', '男', '一个学生', 3), (null, '莉莉', '男', '一个学生', 1), (null, '雪夜', '男', '一个学生', 2), (null, '小明', '女', '一个学生', 1), (null, '小新', '男', '一个学生', 3) ;
异常数据
class_id 不存在的数据
sql-- 插入不正常的数据 INSERT into student VALUES (null, '偷走晚霞的人', '男', '一个学生', 5);
外键约束,不能插入主表中没有的数据
1452 - Cannot add or update a child row: a foreign key constraint fails (`test`.`student`, CONSTRAINT `student_class_fk` FOREIGN KEY (`student_class_id`) REFERENCES `class` (`class_id`))
3.使用alter添加外键
删除外键
sql-- 删除student表中的外键 ALTER TABLE student DROP FOREIGN KEY student_class_fk;
添加外键
sql-- 再次添加外键 ALTER TABLE student ADD FOREIGN KEY(student_class_id) REFERENCES class(class_id);
4.Mysql外键不生效的原因
总:查看存储引擎是不是InnoDB
这里是设置了外键的,仔细检查了语法也没有问题,但是外键不生效。
后面查看了mysql根目录的配置文件,发现自己用的mysql是Mylsam找到 defult-storage-engine
修改引擎
在配置文件中修改。(配置文件在mysql安装的根目录)
default-storage-engine=MyIsam
default-storage-engine=InnoDB
修改完成之后重启mysql
phpystudy的mysql位置
phpystudy可以在phpstudy的根目录下
==》Extension
===》mysql(这个是你自己使用过的mysql)
