欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 汽车 > 维修 > MySql(十三)

MySql(十三)

2025/6/6 10:47:44 来源:https://blog.csdn.net/2301_76862031/article/details/148336597  浏览:    关键词:MySql(十三)

目录

mysql外键约束

准备工作

创建表

插入数据

创建表时添加外键

1..格式

2..创建表student表时,为其添加外键

3.插入数据测试

正常数据

异常数据

3.使用alter添加外键

删除外键

添加外键

4.Mysql外键不生效的原因

修改引擎

phpystudy的mysql位置


mysql外键约束

注:student是从表,class是主表. 在从表中添加外键约束

在从表中添加主表的主键

从表使用 on delete cascade 

        可以在主表删除相关的数据时,把从表相关数据也删除

准备工作

创建表

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 
);CREATE table class (class_id INT PRIMARY KEY AUTO_INCREMENT,class_name VARCHAR(20));

插入数据


-- 插入正常数据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表时,为其添加外键

DROP 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.插入数据测试

正常数据

-- 插入正常数据INSERT into student VALUES
(null, '偷走晚霞的人', '男', '一个学生', 1),
(null, '惜.己', '男', '一个学生', 2),
(null, '小玖', '女', '一个学生', 1),
(null, '张三', '男', '一个学生', 3),
(null, '莉莉', '男', '一个学生', 1),
(null, '雪夜', '男', '一个学生', 2),
(null, '小明', '女', '一个学生', 1),
(null, '小新', '男', '一个学生', 3)
;

异常数据

class_id 不存在的数据

-- 插入不正常的数据
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添加外键

删除外键
-- 删除student表中的外键ALTER TABLE student DROP FOREIGN KEY student_class_fk;

添加外键
-- 再次添加外键
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)

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词