触发器

简介:

一、什么是触发器:

1、触发器是由事件来触发某个操作,这些事件包括insert、update和delete语句。
2、触发器实际是个特殊的存储过程,如果定义了触发程序,当数据库执行这些语句的时候就会激发触发器执行相应的操作;
触发程序是与表有关的命名数据库对象,当表上出现特定事件时,将激活该对象。
3、触发器可以查询其他表,而且可以包含复杂的SQL语句。主要用于满足复杂的业务规则或要求。

二、创建触发器:
1.语法:

create trigger trigger_name trigger_time trigger_event on table_name for each row 
trigger_statement;

(1)trigger_name:触发器名称
(2)trigger_time:触发时机,before或after

before:先完成触发,再增删改,触发的语句先用于监视的增删改,我们就有机会判断、修改即将发生的操作。
after:先完成数据的增删改,再触发,触发的语句晚于监视的增删改操作,无法影响前面的增删改动作。

(3)trigger_event:触发事件,包括insert、update、delete
(4)table_name:表名,即在哪张表上建立触发器
(5)trigger_statement:触发器的程序体,对于多行语句,可以使用begin和end作为开始和结束。

在MySQL触发器中的SQL语句可以关联表中的任意列。但不能直接使用列的名称去标志,那会使系统混淆,因为激活触发器的语句可能已经修改、删除或添加了新的列名,而列的旧名同时存在。
因此必须用这样的语法来标志:“NEW.column_name”或者“OLD.column_name”。
NEW.column_name用来引用新行的一列;
OLD.column_name用来引用更新或删除它之前的已有行的一列。
对于INSERT语句,只有NEW是合法的;
对于DELETE语句,只有OLD才合法;而UPDATE语句可以与NEW或OLD同时使用。

注意事项:
不能在一个表内创建两个(包含两个)以上trigger_time和 trigger_event相同的触发器。

目录
相关文章
|
3月前
|
SQL Oracle 关系型数据库
DML触发器
8月更文挑战第22天
|
6月前
|
SQL 数据库
10. 触发器和事件
10. 触发器和事件
|
6月前
|
SQL 存储
使用触发器
使用触发器。
62 5
|
11月前
|
图形学
触发器事件
触发器事件
|
存储 数据库 数据库管理
触发器
一、什么是触发器 触发器(Trigger)是数据库管理系统中的一种特殊类型的存储过程,它是一段与表相关联的代码,当满足特定的条件时,触发器会自动执行。触发器通常与数据库表的插入、更新或删除操作相关联,用于在数据发生变化时执行特定的操作。 触发器可以在以下情况下被触发执行: 1. 插入触发器(INSERT Trigger):当向表中插入新的数据行时,触发器会被执行。 2. 更新触发器(UPDATE Trigger):当更新表中的数据行时,触发器会被执行。 3. 删除触发器(DELETE Trigger):当从表中删除数据行时,触发器会被执行。 触发器可以用于实现以下功能: 1. 数据完整性约束:
56 0
|
存储 SQL 监控
第17章_触发器
第17章_触发器
140 1
|
存储 关系型数据库 MySQL
创建存储过程以及触发器
创建存储过程以及触发器
|
关系型数据库 MySQL 数据库
MySQL数据库(32):触发器 trigger-2
MySQL数据库(32):触发器 trigger
137 0
|
SQL 数据库 数据安全/隐私保护