7、触发器(trigger)的操作-----第2篇

2024-04-17 03:08
文章标签 操作 触发器 trigger

本文主要是介绍7、触发器(trigger)的操作-----第2篇,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

小结:触发器存在于数据库目录下。

对应第8章
一个项目下有个触发器文件夹。
触发器:不是由程序或手工启动,而是由事件触发。
比如,插入顾客信息时,自动检查电话是否正确,地址是否正确。
在SQL中,只有INSERT语句、DELETE语句、UPDATE语句才会引起触发。

创建触发器

分为“触发只执行一行语句”和“触发执行多行语句”。

最方便方法:右键新建触发器。

比如新建触发器tri_test,模板代码为:DELIMITER $$CREATE/*[DEFINER = { user | CURRENT_USER }]*/TRIGGER `db_name`.`tri_test` BEFORE/AFTER INSERT/UPDATE/DELETEON `db_name`.`<Table Name>`FOR EACH ROW BEGINEND$$DELIMITER ;需要修改三个地方:
一是BEFORE/AFTER INSERT/UPDATE/DELETE,从中选择一个
二是`<Table Name>`,换成对应的引起触发的表名
三是在BEGINEND间加触发执行代码
下面例子:
DELIMITER $$CREATE/*[DEFINER = { user | CURRENT_USER }]*/TRIGGER `db_name`.`tri_test` BEFORE INSERTON `db_name`.`t_dept`FOR EACH ROW BEGININSERT INTO t_diary VALUES(NULL,'t_dept',NOW());END$$DELIMITER ;
--  代码改过后必须点击执行按钮才能生效。

1、触发只执行一行语句

语法:
CREATE TRIGGER 触发器名BEFORE|AFTER 触发活动名(INSERTDELETEUPDATEON 引起触发的表 FOR EACH ROW触发执行语句;

例:
有部门表t_dept和日志表t_diary,触发器需要做到,当向t_dept插入一条记录前,需要把该插入动作记录下来保存到日志表中

CREATE TABLE t_dept(deptno INT(11),dname VARCHAR(20),loc VARCHAR(40)
);
CREATE TABLE t_diary(--  日志序号是自动增加的diaryno INT(11)  PRIMARY KEY AUTO_INCREMENT,--  哪个表在做动作tablename VARCHAR(20),diarytime DATETIME
);
-- 在t_dept表的某一行INSERT语句执行前,触发了向t_diary插入的语句
CREATE TRIGGER tri_diarytimeBEFORE INSERT ON t_dept FOR EACH ROWINSERT INTO t_diary VALUES(NULL,'t_dept',NOW());

下图是当在t_dept插入一行数据后,t_diary触发执行的记录:
这里写图片描述

2、触发执行多行语句

语法:
CREATE TRIGGER 触发器名BEFORE|AFTER 触发活动名(INSERTDELETEUPDATEON 引起触发的表 FOR EACH ROWBEGIN多行执行语句;END

在实际用时小改动

还是上面的表t_dept和t_diary,现在写一个新的触发器
每次t_dept插入一行数据,t_diary会写入两行数据。DELIMITER $$	
CREATE TRIGGER tri_diarytime2BEFORE INSERT ON t_dept FOR EACH ROWBEGININSERT INTO t_diary VALUES(NULL,'t_dept',NOW());INSERT INTO t_diary VALUES(NULL,'t_dept',NOW());END$$
DELIMITER ; 

查看触发器

右键或用命令 SHOW TRIGGERS;

删除触发器

右键或 DROP TRIGGER 触发器名;

这篇关于7、触发器(trigger)的操作-----第2篇的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/910638

相关文章

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

Python位移操作和位运算的实现示例

《Python位移操作和位运算的实现示例》本文主要介绍了Python位移操作和位运算的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 位移操作1.1 左移操作 (<<)1.2 右移操作 (>>)注意事项:2. 位运算2.1

Python ZIP文件操作技巧详解

《PythonZIP文件操作技巧详解》在数据处理和系统开发中,ZIP文件操作是开发者必须掌握的核心技能,Python标准库提供的zipfile模块以简洁的API和跨平台特性,成为处理ZIP文件的首选... 目录一、ZIP文件操作基础三板斧1.1 创建压缩包1.2 解压操作1.3 文件遍历与信息获取二、进阶技

Java中字符串转时间与时间转字符串的操作详解

《Java中字符串转时间与时间转字符串的操作详解》Java的java.time包提供了强大的日期和时间处理功能,通过DateTimeFormatter可以轻松地在日期时间对象和字符串之间进行转换,下面... 目录一、字符串转时间(一)使用预定义格式(二)自定义格式二、时间转字符串(一)使用预定义格式(二)自

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

Python 中的 with open文件操作的最佳实践

《Python中的withopen文件操作的最佳实践》在Python中,withopen()提供了一个简洁而安全的方式来处理文件操作,它不仅能确保文件在操作完成后自动关闭,还能处理文件操作中的异... 目录什么是 with open()?为什么使用 with open()?使用 with open() 进行

SpringQuartz定时任务核心组件JobDetail与Trigger配置

《SpringQuartz定时任务核心组件JobDetail与Trigger配置》Spring框架与Quartz调度器的集成提供了强大而灵活的定时任务解决方案,本文主要介绍了SpringQuartz定... 目录引言一、Spring Quartz基础架构1.1 核心组件概述1.2 Spring集成优势二、J

Linux ls命令操作详解

《Linuxls命令操作详解》通过ls命令,我们可以查看指定目录下的文件和子目录,并结合不同的选项获取详细的文件信息,如权限、大小、修改时间等,:本文主要介绍Linuxls命令详解,需要的朋友可... 目录1. 命令简介2. 命令的基本语法和用法2.1 语法格式2.2 使用示例2.2.1 列出当前目录下的文

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要