当前位置: 首页 > article >正文

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)

http://www.lryc.cn/news/2396263.html

相关文章:

  • iOS —— UI 初探
  • day23-计算机网络-1
  • C语言基础(09)【数组的概念 与一维数组】
  • 【JavaScript】Ajax 侠客行:axios 轻功穿梭服务器间
  • Django数据库连接报错 django.db.utils.NotSupportedError: MySQL 8 or later is required
  • 2025年- H57-Lc165--994.腐烂的橘子(图论,广搜)--Java版
  • 2024 CKA模拟系统制作 | Step-By-Step | 16、题目搭建-sidecar 代理容器日志
  • (9)-Fiddler抓包-Fiddler如何设置捕获Https会话
  • Vue-Router 基础使用
  • 【案例分享】蓝牙红外线影音遥控键盘:瑞昱RTL8752CJF
  • 利用SQL批量修改Nacos配置
  • 网络协议的原理及应用层
  • Express教程【003】:Express获取查询参数
  • Android开发常用Kotlin高级语法
  • 输入ifconfig,发现ens33不见了,无法连接至虚拟机
  • Android Stdio 编译 文件生成,以及Gradle
  • 前端面试准备-4
  • AI赋能金融风控:基于机器学习的智能欺诈检测系统实战教程
  • Java虚拟机内存区域划分
  • 如何下载python的第三方类库
  • Redis击穿,穿透和雪崩详解以及解决方案
  • 网络渗透基础:信息收集
  • [SAP] 如何查询当前屏幕的Tcode?
  • ZigBee 协议:开启物联网低功耗通信新时代
  • JavaScript 模块系统:CJS/AMD/UMD/ESM
  • STM32F407寄存器操作(ADC非连续扫描模式)
  • 生产系统中TongWeb故障应急处理办法
  • PHP学习笔记(十一)
  • PyTorch中 torch.utils.data.DataLoader 的详细解析和读取点云数据示例
  • 直线模组在手术机器人中有哪些技术挑战?