6.1触发器的创建、删除和使用

6.1.1 触发器概述

        触发器是一个被指定关联到表的数据库对象,与表的关系密切,不需要用户调用,在一个表的特定事件出现时将会被激活,此时某些MySql语句会自动执行。
触发器用于实现数据库的完整性,具有以下特点:
       • 可以提供更强大的约束。
       • 可以对数据库中的相关表实现联级更改。
       • 可以评估数据修改前后表的状态,并根据该差异采取措施。
       • 强制表的修改要合乎业务规则。
缺点是增加决策和维护的复杂度。

6.1.2 创建触发器

语法格式:
create TRIGGER trigger_name trigger_time trigger_event 
     on tbl_name for each row trigger_body
说明: 
(1)trigger_name:指定触发器名称。 
(2)trigger_time:触发器被触发的时刻,有两个选项,before用于激活其语句之前触发,after用于激活其语句之后触发。 
(3)trigger_event:触发事件,有insert、update、delete。
        ① insert:在表中插人新行时激活触发器。 
        ②update:更新表中某一行时激活触发器。 
        ③delete:删除表中某一行时激活触发器。 
(4) for each row:用于指定对于受触发事件影响的每一行,都要激活触发器的动作。 
(5)trigger_body:触发动作的主体,即触发体,包含触发器激活时将要执行的语句。 
                            如果要执行多个语句,可使用BEGIN…END复合语句结构。 
在触发器的创建中,每个表、每个事件每次只允许创建一个触发器,所以每条insert、update、delete的前或后可创建一个触发器,每个表最多可创建6个触发器。

【例6.1】在数据库study中的选课表创建触发器T_insertScoreRecord,当向选课表插入一条记录时,显示正在插入记录。

CREATE TRIGGER T_insertScoreRecordAFTER INSERTON 选课 FOR EACH ROWSET @str = '正在插入记录';

验证触发器功能,向选课表通过insert语句插入一条记录。

insert into 选课value('060103','c02','91');
select @str;

1e7e5f449f79412287883b758572c24b.png
6.1.3 删除触发器

语法格式:drop trigger [ schema_name ] trigger_name

说明:
(1)schema_name:可选项,用于指定触发器所在数据库的名称。如果没有指定,则为当前默认数据库。
(2)trigger_name:要删除的数据库名称。

当删除一个表时,同时自动删除该表上的触发器。

【例6.2】删除触发器T_insertScoreRecord

drop trigger T_insertScoreRecord;

455947fdfe3f4dfeb9b23c1d0596a7a5.png
6.1.4 使用触发器

1. insert触发器

在insert语句执行前或执行后执行。
(1)其触发器内可引用一个名为new的虚拟表来访问被插入的行。
(2)在before insert触发器中,new中的值可以被更新。

【例6.3】在数据库study的学生表中创建触发器T_insertStudentRecord,当向学生表插入一条记录时,显示插入记录的学生的姓名。

CREATE TRIGGER T_insertStudentRecordAFTER INSERTON 学生 FOR EACH ROWSET @str = new.姓名;

验证触发器功能,向学生表通过insert语句插入一条记录。

insert into 学生values('060104','刘莉','女','21','19计科2','山东日照');select @str;

5242abe2d885445ca55473cfc5654fee.png
2. update触发器

(1) Insert触发器的触发体内可以用一个名为OLD的虚拟表来访问更新以前的值,也可以引用一个名为new的虚拟表来访问更新以后的值。
(2)在before update触发器中,new中的值可能已被更新。
(3)OLD中的值不能被更新。

【例6.4】在数据库study的课程表中。创建一个触发器T_updateCourseScore。更新课程表中某门课程的课程号时,同时更新选课表中所有相应的课程号。

创建触发器:

CREATE TRIGGER T_updateCourseScoreAFTER UPDATE ON 课程 FOR EACH ROWBEGINUPDATE 选课 SET 课程号 = NEW.课程号 WHERE 课程号 = OLD.课程号;END;

验证功能:

update 课程 set 课程号 = 'c03' where 课程号 = 'c06';select * from 选课 where 课程号 = 'C06';

 

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

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

相关文章

深入了解RSA加密算法

目录 前言 一、什么是RSA? 二、RSA加密的基本概念 1.非对称加密 2.密钥生成 3.加密和解密 三、RSA加密的工作原理 四、RSA的应用场景 五、RSA加密解密的实现 六、RSA算法的局限性及改进措施 前言 在当今的数字化时代,信息的安全性成为了人们关注…

密码学-密码协议之零知识证明

一、前言 零知识证明实际上一种密码协议,该协议的一方称为证明者(Prover),通常用P表示,协议的另一方是验证者(Verifier),一般用V表示。零知识证明是指P试图使V相信某个论断是正确的,但却不向V提供任何有用的信息&…

Photoshop中图像美化工具的应用

Photoshop中图像美化工具的应用 Photoshop中的裁剪工具Photoshop中的修饰工具模糊工具锐化工具涂抹工具 Photoshop中的颜色调整工具减淡工具加深工具海绵工具 Photoshop中的修复工具仿制图章工具污点修复画笔工具修复画笔工具修补工具内容感知移动工具红眼工具 Photoshop中的裁…

【杂记-浅谈以太网IP数据帧】

一、以太网数据帧 以太网数据帧是网络通信的基础单元,遵循IEEE 802.3标准,用于在以太网中传输数据。一个典型的以太网数据帧包括前导码、帧开始符、目的MAC地址、源MAC地址、类型或长度字段、数据载荷和帧校验序列。其中,类型字段指明了上层…

数据可视化:让数据讲述故事

数据可视化:让数据讲述故事 引言 在信息爆炸的时代,数据无处不在。然而,数据本身并不直观,很难从中直接获取有价值的信息。数据可视化作为一种强大的工具,能够帮助我们揭示数据背后的故事,让我们以更直观…

Spring Boot顶层接口实现类注入项目的方法

1、背景 在项目中,我们通常会具有同一特性的业务类定义一个顶层接口,让业务类实现这个接口,通过接口规范来管理这些类。我们将这些实现接口的业务类交托给Spring容器接口后,有时候需要根据业务类型来选择动态选择对应的业务类阿里…

尚品汇-(二)

一:环境安装 1.安装JAVA 运行环境 第一步:上传或下载安装包 cd /usr/local jdk-8u152-linux-x64.tar.gz 第二步:解压安装包 tar -zxvf jdk-8u152-linux-x64.tar.gz 第三步:建立软连接(快捷方式) ln -…

SpringBoot配置第三方专业缓存技术Redis

Redis缓存技术 Redis(Remote Dictionary Server)是一个开源的内存中数据结构存储系统,通常用作数据库、缓存和消息中间件。它支持多种数据结构,如字符串、哈希表、列表、集合、有序集合等,并提供了丰富的功能和灵活的…

4.1 初探Spring Boot

初探Spring Boot实战概述 Spring Boot简介 Spring Boot是一个开源的Java框架,由Pivotal团队(现为VMware的一部分)开发,旨在简化Spring应用程序的创建和部署过程。它通过提供一系列自动化配置、独立运行的特性和微服务支持&#…

类加载的初始化阶段的奥秘

一、概述 初始化阶段是类加载机制(加载,链接(验证,准备,解析),初始化)的最后一步。在准备阶段已经为类变量赋过一次值(默认为0或null)。在初始化阶段&#xf…

HTML和CSS基础(一)

前言 HTML(HyperText Markup Language)是一种用于创建网页的标准标记语言。它由各种标签组成,这些标签定义了网页的结构和内容。HTML的早期形式诞生于1989年,由CERN的物理学家Tim Berners-Lee发明,最初用于在科学家之…

js 刷题常用方法

Object 对象共有 toString()valueOf()obj.keys()obj.values()obj.entries()for of 循环…扩展运算符Array.of()Array.from() 数组使用时 toString 返回以逗号分隔的字符串valueOf 返回数组本身 Array 数组 创建数组 Array.from(可迭代对象)Array.of(传入一组参数) let arr…

C语言 | Leetcode C语言题解之第160题相交链表

题目: 题解: struct ListNode *getIntersectionNode(struct ListNode *headA, struct ListNode *headB) {if (headA NULL || headB NULL) {return NULL;}struct ListNode *pA headA, *pB headB;while (pA ! pB) {pA pA NULL ? headB : pA->ne…

windows11 x64 23H2 企业纯净版2024.6.16

闲来无事试安装了下da_nao_yan的 【6月12日更新】Windows11 22631.3737企业版 23H2 自用优化版 (原版地址:https://bbs.pcbeta.com/viewthread-1985546-1-1.html),感觉比原版流畅多了,重新按照自己习惯封装了下&#x…

C++作业第四天

#include <iostream> using namespace std; class Per { private: string name; int age; int *high; double *weight; public: //构造函数 Per() { cout << "Per的无参构造" << endl; } Per(str…

Python获取一个列表的全组合

numList [1, 3, 5, 7, 9] from itertools import combinationsfor i in range(1, len(numList) 1): # xrange will return the values 1,2,3,4 in this loopprint(list(combinations(numList, i)))输出&#xff1a; [(1,), (3,), (5,), (7,), (9,)] [(1, 3), (1, 5), (1, 7)…

通讯的一些基本概念 -网卡 -网段 -网桥 -路由表

网卡&#xff08;Network Interface Card, NIC&#xff09; 网卡是安装在计算机或其他设备上的硬件组件&#xff0c;它允许设备通过有线或无线方式连接到计算机网络。网卡工作在OSI模型的数据链路层&#xff08;第二层&#xff09;和物理层&#xff08;第一层&#xff09;&…

排序——希尔排序

希尔排序实际上是插入排序的优化&#xff0c;所以要先介绍插入排序。 目录 插入排序 思想 演示 代码实现 总结 希尔排序 思想 演示 代码 总结 插入排序 思想 又称直接插入排序。它的基本思想是将一个值插入到一个有序序列中。直至将所有的值都插入完。 演示 假设数…

Web前端开发的过程:深入剖析与精彩演绎

Web前端开发的过程&#xff1a;深入剖析与精彩演绎 在数字化时代&#xff0c;Web前端开发作为构建用户界面的关键环节&#xff0c;其重要性不言而喻。这一过程涉及众多技术细节和创意构思&#xff0c;充满了挑战与机遇。本文将从四个方面、五个方面、六个方面和七个方面&#…

Java并发编程三大神器之Semaphore

Java并发编程三大神器之Semaphore 1、Semaphore是什么2、Semaphore小试牛刀3、Semaphore和CountDownLatch组合使用4、Semaphore常用方法5、Semaphore 结语 1、Semaphore是什么 Semaphore 是一个计数信号量&#xff0c;是JDK1.5引入的一个并发工具类&#xff0c;位于java.util.…