【MySQL】一文带你搞定 外键约束&其【更新/删除行为】(可cv代码&案例演示)

前言

大家好吖,欢迎来到 YY 滴MySQL系列 ,热烈欢迎! 本章主要内容面向接触过C++ Linux的老铁
主要内容含:
在这里插入图片描述

欢迎订阅 YY滴C++专栏!更多干货持续更新!以下是传送门!

  • YY的《C++》专栏
  • YY的《C++11》专栏
  • YY的《Linux》专栏
  • YY的《数据结构》专栏
  • YY的《C语言基础》专栏
  • YY的《初学者易错点》专栏
  • YY的《小小知识点》专栏
  • YY的《单片机期末速过》专栏
  • YY的《C++期末速过》专栏
  • YY的《单片机》专栏
  • YY的《STM32》专栏
  • YY的《数据库》专栏
  • YY的《数据库原理》专栏

目录

  • 一.约束概述&约束关键字盘点分类&应用场景&多个约束注意事项
  • 二.约束演示(根据需求,完成表结构的创建)
    • ※用图形化界面工具一样可以设置约束
    • ※数据准备
  • 三.外键约束的【添加 / 删除】操作
    • 1.外键约束概念&应用场景&外键约束添加语法
    • 2.外键约束【添加 / 删除 操作】(可cv语句)
  • 四.针对 外键约束【更新 / 删除 】的 on行为(可cv语句)
    • 1.行为一览&语法
    • 2.CASCADE级联演示
    • 3.用图形化界面工具添加行为

一.约束概述&约束关键字盘点分类&应用场景&多个约束注意事项

  • 如下所示
    在这里插入图片描述

约束应用场景:

  • 注意:约束是 作用于表中字段上 的,可以在 创建表/修改表 的时候添加约束。

多个约束注意事项

  • 多个约束, 空格分开 即可

二.约束演示(根据需求,完成表结构的创建)

  • 需求如下所示
  • 我们先确定需求所用的 关键字 在这里插入图片描述
create table user(
    id int primary key auto_increment comment'主键',
    name varchar(10) not null unique comment'姓名',
    age int check(age>0 && age<=120)comment'年龄',
    status char(1)default'1'comment'状态',gender char(1)comment'性别'
)comment'用户表'--插入数据
insert into user(name,age,status,gender) values('Tom1',19,'1','男'),'Tom2',25,'0','男');

※用图形化界面工具一样可以设置约束

  • 如下图所示,创建表时,可以选择约束
    在这里插入图片描述

※数据准备

create table dept(
    id   int auto_increment comment 'ID' primary key,
    name varchar(50) not null comment '部门名称'
)comment '部门表';
INSERT INTO dept (id, name) VALUES (1, '研发部'), (2, '市场部'),(3, '财务部'), (4, '销售部'), (5, '总经办');


create table emp(
    id  int auto_increment comment 'ID' primary key,
    name varchar(50) not null comment '姓名',
    age  int comment '年龄',
    job varchar(20) comment '职位',
    salary int comment '薪资',
    entrydate date comment '入职时间',
    managerid int comment '直属领导ID',
    dept_id int comment '部门ID'
)comment '员工表';

INSERT INTO emp (id, name, age, job,salary, entrydate, managerid, dept_id) VALUES
            (1, '金庸', 66, '总裁',20000, '2000-01-01', null,5),(2, '张无忌', 20, '项目经理',12500, '2005-12-05', 1,1),
            (3, '杨逍', 33, '开发', 8400,'2000-11-03', 2,1),(4, '韦一笑', 48, '开发',11000, '2002-02-05', 2,1),
            (5, '常遇春', 43, '开发',10500, '2004-09-07', 3,1),(6, '小昭', 19, '程序员鼓励师',6600, '2004-10-12', 2,1);

-- 添加外键
alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id);

-- 删除外键
alter table emp drop foreign key fk_emp_dept_id;

三.外键约束的【添加 / 删除】操作

1.外键约束概念&应用场景&外键约束添加语法

  • 外键约束: 外键用来让两张表的数据之间 建立连接 ,从而保证数据的 一致性和完整性
  • 外键约束应用场景举例:
  • 如下图所示,我们希望关联dept_id和部门表dept
  • 注意:目前上述的两张表,在数据库层面,并未建立外键关联,所以是无法保证数据的一致性和完整性的。 在这里插入图片描述
  • 外键约束添加语法如下所示:
    在这里插入图片描述
  • 外键约束删除语法如下所示:
alter table 表名  drop 外键名称 foreign key(外键字段名) references 主表(主表列名);

2.外键约束【添加 / 删除 操作】(可cv语句)

  • 我们目前有两张表
    在这里插入图片描述
  • 要建立如下【外键关联】
    在这里插入图片描述
--添加外键
alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id);
  • 添加外键后,我们发现删除其中表的数据时,会失败
    在这里插入图片描述
--删除外键
alter table emp drop foreign key fk_emp_dept_id;

四.针对 外键约束【更新 / 删除 】的 on行为(可cv语句)

1.行为一览&语法

  • 如下所示
  • cascade即我们所熟知的 级联 在这里插入图片描述
  • 语法如下所示

在这里插入图片描述

ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY(外键字段)REFERENCES 主表名(主表字段名)ON UPDATE CASCADE ON DELETE CASCADE;

2.CASCADE级联演示

  • 针对我们在博客上文,添加外键;我们进行级联行为
外键的删除和更新行为
alter table emp add constraint fk_emp_dept_id foreign key (dept_id) references dept(id) on update cascade on delete cascade
  • 此时,我们删除emp表/dept表中某个数据时,对应的数据也会一起被删除

3.用图形化界面工具添加行为

  • 如下图所示,我们右键表点击MODIFY,找到外键选项
    在这里插入图片描述
  • 我们即可在其中选择其【更新 / 删除行为】
    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/507785.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

新生报到系统的设计与实现(论文+源码)_kaic

摘 要 互联网发展至今&#xff0c;无论是其理论还是技术都已经成熟&#xff0c;而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播&#xff0c;搭配信息管理工具可以很好地为人们提供服务。针对新生报到信息管理混乱&#xff0c;出错率高&#xff0c;信息安全性差…

突发: xz-utils 被注入后门 (CVE-2024-3094)

Andres Freund 在 2024 年 3 月 29 日发现了一个在 xz-utils 注入的后门&#xff1b;使用了 xz/lzma 5.6.0 / 5.6.1 的项目皆受影响。 杀伤力: 当前还未完全清楚&#xff1b;但 openssh 的 sshd 首当其冲&#xff1b;注入的代码会 Hook OpenSSH 的 RSA_public_decrypt 函数&a…

第四百三十六回

文章目录 1. 概念介绍2. 思路与方法2.1 实现思路2.2 实现方法 3. 示例代码4. 内容总结 我们在上一章回中介绍了"不同平台上换行的问题"相关的内容&#xff0c;本章回中将介绍如何在页面上显示蒙板层.闲话休提&#xff0c;让我们一起Talk Flutter吧。 1. 概念介绍 我…

[中级]软考_软件设计_计算机组成与体系结构_04_寻址地址

寻址地址 概念指令的概念 寻址方式立即寻址方式直接寻址方式间接寻址方式寄存器寻址方式寄存器间接寻址方式往年真题 概念 指令的概念 一条指令就是机器语言的一个语句&#xff0c;它是一组有意义的二进制代码&#xff0c;指令的基本格式如下&#xff1a; 操作码字段地址码字…

SAP 未清销售订单的取值

每个公司都会有自己的销售报表&#xff0c; 一般来说VA05的都满足不了客户的定制化需求。 所以都要进行自定义报表的开发&#xff0c; 在开发的过程中&#xff0c;也会有未清销售订单和已清销售订单的区分 一开始我的想法是&#xff0c;根据销售订单去找交货单累计已交货的…

面向对象程序之多态

1.多态的概念 简单来说&#xff0c;就是多种形态&#xff0c;具体点就是去完成某个行为&#xff0c;不同的对象去完成会有不同的形态。 举个例子&#xff1a;对于动物&#xff0c;他们吃的都是食物&#xff0c;但狗吃的是狗粮&#xff0c;猫吃的是猫粮&#xff0c;去完成吃这个…

lua脚本在redis集群中哈希槽分片问题

上文说到&#xff0c;通过用redis lua脚本实现时间窗分布式限流 可以操作redis lua脚本来实现时间窗限流&#xff0c;在执行lua脚本的时候&#xff0c;参数中有个keys列表&#xff0c;当lua脚本中如果有操作多个key的情况&#xff0c;就可以传个key列表了。通常情况下&#xff…

Java封装最佳实践:打造高内聚、低耦合的优雅代码~

​ 个人主页&#xff1a;秋风起&#xff0c;再归来~ 文章专栏&#xff1a;javaSE的修炼之路 个人格言&#xff1a;悟已往之不谏&#xff0c;知来者犹可追 克心守己&#xff0c;律己则安&#xff01; 1、封装 1.1 封装的概念 面向对象程序三大…

python练习二

# Demo85def pai_xu(ls_test):#创建一个列表排序函数命名为pai_xu# 对创建的函数进行注释"""这是一个关于列表正序/倒序排列的函数:param ls_test: 需要排序的列表:return:"""ls1 [int(ls_test[i]) for i in range(len(ls_test))]#对input输入的…

surfer绘制等值线图

surfer介绍 Surfer软件&#xff0c;是美国Golden Software公司编制的一款以画三维图的软件。该软件具有强大的插值功能和绘制图件能力&#xff0c;可用来处理XYZ数据&#xff0c;是地质工作者常用的专业成图软件&#xff08;来源于百度百科&#xff09;。 surfer可以用来绘制…

计算机网络—TCP协议详解:特性、应用(1)

&#x1f3ac;慕斯主页&#xff1a;修仙—别有洞天 ♈️今日夜电波&#xff1a;マリンブルーの庭園—ずっと真夜中でいいのに。 0:34━━━━━━️&#x1f49f;──────── 3:34 &#x1f504; ◀️…

Java中常见的锁策略

目录 乐观锁 vs 悲观锁 悲观锁: 乐观锁&#xff1a; 重量级锁 vs 轻量级锁 ⾃旋锁&#xff08;Spin Lock&#xff09; 公平锁 vs 非公平锁 可重⼊锁 vs 不可重入锁 读写锁 乐观锁 vs 悲观锁 悲观锁: 总是假设最坏的情况&#xff0c;每次去拿数据的时候都认为别…

3d整体模型怎么拆图---模大狮模型网

3D整体模型怎么拆图 一、模型准备 在进行3D整体模型的拆图之前&#xff0c;首先需要确保模型的构造清晰明了&#xff0c;各个部件之间的连接关系明确&#xff0c;并且模型的层级结构已经建立完成。 二、确定拆图方式 拆解方向&#xff1a;根据模型的结构和设计需求&#xff…

教你用Fiddler捕获HTTPS请求

安装Fiddler 这里不特别说明了&#xff0c;网上搜索一大把&#xff0c;根据安装引导一步步安装即可。&#xff08;这里采用的是fiddler v4.6&#xff09; 配置Fiddler 1、打开fiddler配置Tools –>Telerik Fiddler Options。 2、打开HTTPS配置项&#xff0c;勾选“Captur…

Leetcode-2580-统计将重叠区间合并成组的方案数-c++

题目详见https://leetcode.cn/problems/count-ways-to-group-overlapping-ranges/ 题目要求将最后的ranges分为两个组。也就是说当你的ranges已经满足题目要求的时候&#xff0c;这两个组怎么分是随意的&#xff0c;这里也就引出了 2 k 2^k 2k 的由来&#xff0c;其实就是每组…

Leetcode-2810-故障键盘-c++

题目详见https://leetcode.cn/problems/faulty-keyboard/ 题解 这道题的关键是如何合理地使用STL&#xff0c;毕竟是一道简单题。 之前常用到的Vector容器是单向开口的连续内存空间 deque则是一种双向开口的连续线性空间&#xff0c;又称双端动态数组。所谓的双向开口&#x…

Windows Server 2022 使用ApacheDS用户远程桌面登录服务器

Windows Server 2022 使用ApacheDS用户远程桌面登录服务器 1、接上篇 Windows Server 2022 使用ApacheDS用户认证 使用Administrator用户远程登录192.168.1.100windows server&#xff0c;打开pGina软件 2、输入刚刚在ApacheDS中的新添加的用户测试一下&#xff0c;会自动添加…

200个有趣的HTML前端游戏项目合集(持续更新中)

&#x1f482; 个人网站:【 摸鱼游戏】【神级代码资源网站】【工具大全】&#x1f91f; 一站式轻松构建小程序、Web网站、移动应用&#xff1a;&#x1f449;注册地址&#x1f91f; 基于Web端打造的&#xff1a;&#x1f449;轻量化工具创作平台&#x1f485; 想寻找共同学习交…

[实时流基础 flink] 窗口

在批处理统计中&#xff0c;我们可以等待一批数据都到齐后&#xff0c;统一处理。但是在实时处理统计中&#xff0c;我们是来一条就得处理一条&#xff0c;那么我们怎么统计最近一段时间内的数据呢&#xff1f;引入“窗口”。 文章目录 6.1 窗口的概念6.2 窗口的分类**1&#x…

让接口自动化测试更简单

HTTP 接口测试很简单&#xff0c;不管工具、框架、还是平台&#xff0c;只要很的好的几个点就是好工具。 测试数据问题&#xff1a;比如删除接口&#xff0c;重复执行还能保持结果一致&#xff0c;必定要做数据初始化。接口依赖问题&#xff1a;B 接口依赖 A 的返回值&#xf…