MySql(十三)

目录

mysql外键约束

准备工作

创建表

插入数据

创建表时添加外键

1..格式

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

3.插入数据测试

正常数据

异常数据

3.使用alter添加外键

删除外键

添加外键

4.Mysql外键不生效的原因

修改引擎

phpystudy的mysql位置


mysql外键约束

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

在从表中添加主表的主键

从表使用 on delete cascade

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

准备工作

创建表

sql 复制代码
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)
	
);

插入数据

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表时,为其添加外键

sql 复制代码
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.插入数据测试

正常数据
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)

相关推荐
七夜zippoe1 天前
领域驱动设计在Python中的实现:从理论到生产级实践
数据库·python·sqlite·ddd·pydantic
小CC吃豆子1 天前
Qt的信号与槽机制
开发语言·数据库·qt
·云扬·1 天前
系统与MySQL核心监控指标及操作指南
android·数据库·mysql
七夜zippoe1 天前
数据库事务隔离级别与Spring传播行为深度解析
java·数据库·spring·mvcc·acid·myslq
VX:Fegn08951 天前
计算机毕业设计|基于springboot + vue智慧养老院管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
霖霖总总1 天前
[小技巧15]深入解读 MySQL sql_mode:从原理到实践,规避常见坑
sql·mysql
浩瀚之水_csdn1 天前
python字符串解析
前端·数据库·python
luffy54591 天前
Windows下安装postgresql扩展pg_vector实现向量存储
数据库·postgresql
列御寇1 天前
MongoDB分片集群——mongos组件(mongos进程)
数据库·mongodb
lytao1231 天前
MySQL高可用集群部署与运维完整手册
运维·数据库·mysql·database