MySQL的SQL语句之触发器的创建和应用

触发器  Trigger

一.触发器

作用:当检测到某种数据表发生数据变化时,自动执行操作,保证数据的完整性,保证数据的一致性。

1.创建一个触发器

如上图所示,查看这个create的帮助信息的时候,这个create trigger就是创建触发器的意思。

如上图所示,这是创建触发器的具体语法,方括号括起来的可有可无。

首先是触发器的名称

触发器执行的时间即

BEFORE:表示在触发事件发生之前执行触发器。
AFTER:表示在触发事件发生之后执行触发器。

触发器执行的触发事件

触发器所具体执行的操作。

触发器执行的时间即

BEFORE:表示在触发事件发生之前执行触发器。
AFTER:表示在触发事件发生之后执行触发器。

触发器执行的触发事件

触发器所具体执行的操作。

如上图所示,就是在MySQL数据库中触发器的语法。

案例1:当检测到人员增加的时候,数量自动增加。

如上图所示,这是在为创建触发器做准备工作。

首先是创建了一个指定字符集为utf8的数据库为testdb

然后在这个数据库中创建了一个user表,其中表的字段设置为三个字段,分别是id字段,name字段,age字段,其中的id字段设置为int类型的数据,主键属性,不空,并且配置了自增的属性。

name字段设置了字段类型的数据0

age字段存入int类型的数据。

随后又创建了number表,这个number表中只有number一个字段,这个字段只存入int类型的数据.

向user表的name,age字段插入数据,user01,age为20

向number表的number字段插入数据1

随后可以使用select * from 来查看表的信息。

如上图所示,这就是把SQL语句的结束符改成双叹号。方便写触发器。

如上图所示,这是在MySQL数据库中修改SQL语句的结束符为双叹号,

创建触发器,设置触发器名称为number_auto_add

并且设置这个触发器的执行是在触发事件之后。

具体的触发事件,即导致触发器执行的事件是向表user插入一条数据的时候,触发器开始执行。

随后的begin和end之间是触发体,即触发器具体要执行的命令。

即当user表中的name和age字段更新过后,就执行update表number中的number字段的数值,使得该字段的数值加一。

并且创建触发器,当user表中的数据每增加一行,此时number表中number字段的数值就加一。

触发器中的for each row的意思是让触发器去检测指定表中每行数据的变化。

如上图所示,这就是for each row的意思,检测指定表中每一行数据的变化。所以当表user中的数据增加两行以后,number表中的number字段的数值也就增加2

如上图所示,这是将MySQL数据库中的SQL语句的命令结束符修改为英文分号;

案例2:检测到人员减少,数量自动减少

如上图所示,这是在创建一个触发器

触发器名称为number_auto_reduce

触发器的执行是在触发事件之后,

触发事件是当删除表user中的内容时,执行触发体

其中begin和end之间的触发体是更新number表  set  number字段的数值减去一。

如上图所示,这是对启动触发器的结果进行检验,

案例3:检测到员工增加时,自动添加工资信息

如上图所示,创建了员工表和薪资表,并为这两张表增添新的数据。

new代表的是worker表中新增加的一行信息,而name代表的是新增加的一行信息中的name用户名字段的数据。

new代表的是新数据,对于一张表来说,新增加的一行数据叫做新数据,使用update修改之后的也叫新数据。都可以使用这个new来标识新数据。

old代表的是旧数据是现有的数据。

如上图所示,当我们在表worker中添加新数据后,工资表自动更新,触发器执行触发体。

案例4:检测员工离职时,自动删除其工资信息。

如上图所示,这又是一个触发器,当员工表中有删除操作发生之后,执行触发体,

删除旧的薪资表中的旧数据。

如上图所示,这是触发器的效果演示

new 新数据【添加,更新】

old 旧数据,表中现有的数据

案例5:当检测到员工信息修改时,工资信息自动修改

如上图所示,创建触发器,当员工表中触发更新操作的时候,更新薪资表中旧的name字段数据为新的name字段数据。

如上图所示,是触发器的执行效果。

2.查看触发器

如上图所示,这是在数据库软件中查看触发器的操作,

3.删除触发器

如上图所示,这是删除触发器的操作。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

服务器数据恢复—DELL EqualLogic PS6100系列存储简介及如何收集故障信息?

DELL EqualLogic PS6100系列存储采用虚拟ISCSI SAN阵列,支持VMware、Solaris、Linux、Mac、HP-UX、AIX操作系统,提供全套企业级数据保护和管理功能,具有可扩展性和容错功能。DELL EqualLogic PS6100系列存储介绍: 1、上层应用基础…

什么是无限钱包系统?有什么优势?

在数字货币风起云涌的今天,一个名为“无限钱包系统”的创新平台正悄然引领着行业的变革。它不仅重新定义了数字资产的管理方式,更以卓越的安全性、便捷的操作体验以及前瞻性的技术理念,成为了广大数字货币爱好者心中的理想之选。 一、数字货币…

API网关 - JWT认证 ; 原理概述与具体实践样例

API网关主要提供的能力,就是协议转换,安全,限流等能力。 本文主要是分享 如何基于API网关实现 JWT 认证 。 包含了JWT认证的流程,原理,与具体的配置样例 API网关认证的重要性 在现代Web应用和微服务架构中&#x…

前端加密解密

一、 AES 加密与解密 高级加密标准(AES,Advanced Encryption Standard)为最常见的对称加密算法(微信小程序加密传输就是用这个加密算法的)。是一种对称加密算法也就是加密和解密用相同的密钥; 1.1 使用 crypto-js 实现 AES 加密 1.1.1 参数说明 data 要加密的明文key 秘钥iv …

基于知识引导提示的因果概念提取(论文复现)

基于知识引导提示的因果概念提取(论文复现) 本文所涉及所有资源均在传知代码平台可获取 文章目录 基于知识引导提示的因果概念提取(论文复现)论文概述论文方法提示构造器获取典型概念集聚类典型概念构建训练数据训练主题分类器概念提取器输入构造指针网络置信度评分训练损失…

【element ui系列】分享几种实现el-table表格单选的方法

在实际的开发中,经常会用到从表格中选择一条记录的情况,虽然官方给出的例子,但是给人感觉看起来不明显,于是,在此基础上做了改进。接下来,介绍两种常见的实现方法: 1、采用复选框(checkbox)实现…

63 mysql 的 行锁

前言 我们这里来说的就是 我们在 mysql 这边常见的 几种锁 行共享锁, 行排他锁, 表意向共享锁, 表意向排他锁, 表共享锁, 表排他锁 意向共享锁, 意向排他锁, 主要是 为了表粒度的锁获取的同步判断, 提升效率 意向共享锁, 意向排他锁 这边主要的逻辑意义是数据表中是否有任…

江协科技STM32学习- P26 UART串口外设

🚀write in front🚀 🔎大家好,我是黄桃罐头,希望你看完之后,能对你有所帮助,不足请指正!共同学习交流 🎁欢迎各位→点赞👍 收藏⭐️ 留言📝​…

使用 ADB 在某个特定时间点点击 Android 设备上的某个按钮

前提条件 安装 ADB:确保你已经在计算机上安装了 Android SDK(或单独的 ADB)。并将其添加到系统环境变量中,以便你可以在命令行中运行 adb。 USB调试:确保 Android 设备已启用 USB 调试模式。这可以在设备的“设置” -…

mint-ui Picker 显示异常

mint-ui Picker 显示异常 现象 最近一个老项目页面显示异常&#xff0c;使用mint-ui Picker显示异常,直接显示成了 数据对象&#xff0c;而不是具体travelName 字段 组件 mint-ui Picker 使用方式(vue方式) // template <mt-picker :slots"slots" value-key…

FastAPI性能对比:同步vs异步

大家好&#xff0c;FastAPI已成为构建Python API的最流行框架之一&#xff0c;因其速度和易用性而广受欢迎。但在构建高性能应用程序时&#xff0c;使用同步&#xff08;sync&#xff09;还是异步&#xff08;async&#xff09;代码执行是很重要的问题。本文将通过现实世界的性…

wx.setNavigationBarColor动态设置导航栏颜色无效(亲测有效)

wx.setNavigationBarColor动态设置导航栏颜色无效&#xff08;亲测有效&#xff09; 问题描述问题分析问题解决注意 问题描述 wx.setNavigationBarColor({frontColor: #E6E6E6,backgroundColor: #E6E6E6 })上面的代码设置后导航栏颜色没有变化&#xff0c;查看了app.json 以及…

Blender进阶:贴图与UV

9 UV 9.1 贴图与UV UV&#xff0c;指定每个面顶点在贴图上的坐标 演示&#xff1a; 1、添加物体 2、添加贴图&#xff0c;即图片纹理节点 3、进入UV Edit工作区 4、右边&#xff0c;选择一个面 5、左边&#xff0c;选择一个面&#xff0c;移动这个面 9.2 电子表格 电子…

利用LangChain与LLM打造个性化私有文档搜索系统

我们知道LLM&#xff08;大语言模型&#xff09;的底模是基于已经过期的公开数据训练出来的&#xff0c;对于新的知识或者私有化的数据LLM一般无法作答&#xff0c;此时LLM会出现“幻觉”。针对“幻觉”问题&#xff0c;一般的解决方案是采用RAG做检索增强。 但是我们不可能把…

PostgreSQL-06-入门篇-集合运算

文章目录 1. UNION 组合多个查询的结果集简介带有 ORDER BY 子句的 UNION设置样例表PostgreSQL UNION 示例1) 简单的 PostgreSQL UNION 示例2) PostgreSQL UNION ALL 示例3) 带 ORDER BY 子句 UNION ALL 示例 2. INTERSECT 取交集简介带 ORDER BY 子句的 INTERSECT 操作Postgre…

云计算作业二Spark:问题解决备忘

安装spark 教程源地址&#xff1a;https://blog.csdn.net/weixin_52564218/article/details/141090528 镜像下载 教程给的官网下载地址很慢&#xff0c;https://archive.apache.org/dist/spark/spark-3.1.1/ 这里的镜像快很多&#xff1a; 清华软件源&#xff1a;https://mi…

(51)MATLAB迫零均衡器系统建模与性能仿真

文章目录 前言一、迫零均衡器性能仿真说明二、迫零均衡器系统建模与性能仿真代码1.仿真代码2.代码说明3.迫零均衡器zf_equalizer的MATLAB源码 三、仿真结果1.信道的冲击响应2.频率响应3.迫零均衡器的输入和输出 前言 使用MATLAB对迫零均衡器系统进行建模仿真&#xff0c;完整的…

【C#】编写计算机选课程序

文章目录 一、引言二、程序概述三、程序设计四、 界面设计五、代码实现六、为每一个选项添加事件七、事件处理八、完成展示 一、引言 在这篇文章中&#xff0c;我将介绍如何开发一个简单的计算机选课程序。这个程序将允许学生根据自己的需求选择不同等级的课程&#xff0c;并即…

【AIGC】AI工作流workflow实践:构建日报

workflow实践 引言实现步骤分析实践创建 dify workflow 应用创建工作流内部节点1、设置输入字段2、创建两个LLM节点3、设置结束节点 运行工作流 结语 引言 工作流 workflow 是现在 LLM 很重要的一个概念&#xff0c;因为对于一个模型来说&#xff0c;非常复杂的问题很难一次性…

无人机飞手考证热,装调检修技术详解

随着无人机技术的飞速发展和广泛应用&#xff0c;无人机飞手考证热正在持续升温。无人机飞手不仅需要掌握飞行技能&#xff0c;还需要具备装调检修技术&#xff0c;以确保无人机的安全、稳定和高效运行。以下是对无人机飞手考证及装调检修技术的详细解析&#xff1a; 一、无人机…