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)

相关推荐
IT 小阿姨(数据库)18 分钟前
PostgreSQL 之上的开源时序数据库 TimescaleDB 详解
运维·数据库·sql·postgresql·开源·centos·时序数据库
颜大哦35 分钟前
linux安装mysql
linux·运维·mysql·adb
熊文豪1 小时前
openEuler 云原生实战:部署高性能 Redis 集群与压测分析
数据库·redis·云原生·openeuler
GTgiantech2 小时前
科普SFP 封装光模块教程
服务器·网络·数据库
深圳市恒讯科技2 小时前
如何在服务器上安装和配置数据库(如MySQL)?
服务器·数据库·mysql
言之。2 小时前
TiDB分布式数据库技术架构概述
数据库·分布式·tidb
万事大吉CC2 小时前
SQL表设计与约束教程
数据库·sql
员大头硬花生2 小时前
七、InnoDB引擎-架构-后台线程
java·数据库·mysql
Ryan ZX3 小时前
etcd 高可用分布式键值存储
数据库·分布式·etcd
IT教程资源C3 小时前
(N_151)基于微信小程序校园学生活动管理平台
mysql·vue·前后端分离·校园活动小程序·springboot校园活动