触发器 trigger

触发器的执行不是由程序调用,也不是手工启动,而是由事件来触发。它在插入,删除或修改特定表中的数据时触发执行。

触发器(trigger):监视某种情况,并触发某种操作。

触发器创建语法四要素:1.监视地点(table) 2.监视事件(insert/update/delete) 3.触发时间(after/before) 4.触发事件(insert/update/delete)


创建触发器:

create TRIGGER tr_test
before/AFTER
insert/update/DELETE
on 
表名
for each row 
BEGIN
SQL语句集

END

例:有两张表,book表以及orders表,当向orders表中插入数据,触发触发器,book表发生改变

create TRIGGER tr_order
before 
INSERT
on 
orders
for each ROW
BEGIN
update book set book_num = book_num-new.order_num where book_name = new.order_name;
END


查看触发器:

show triggers


删除触发器:

drop trigger 触发器名



### 查询触发器相关语句或操作 在数据库中,触发器Trigger)是一种与表相关的特殊对象,当指定事件(如 `INSERT`、`UPDATE`、`DELETE`)发生时,触发器会自动执行预定义的操作。为了管理和维护触发器,数据库提供了多种查询和操作语句。 #### 查询触发器信息 1. **查看触发器定义** 在 SQL Server 中,可以使用系统存储过程 `sp_helptext` 来查看触发器的定义文本。 ```sql EXEC sp_helptext 'trigger_name'; ``` 2. **查看触发器基本信息** 使用 `sp_help` 可以查看触发器的名称、类型和创建时间等基本信息。 ```sql EXEC sp_help 'trigger_name'; ``` 3. **查询系统视图中的触发器信息** 在 MySQL 中,可以通过系统表 `INFORMATION_SCHEMA.TRIGGERS` 来查询触发器的信息。 ```sql SELECT * FROM INFORMATION_SCHEMA.TRIGGERS WHERE TRIGGER_SCHEMA = 'your_database_name'; ``` 4. **查看特定表的触发器** 在 MySQL 中,可以使用 `SHOW TRIGGERS` 语句来查看与特定表相关的触发器。 ```sql SHOW TRIGGERS FROM your_database_name WHERE `Table` = 'your_table_name'; ``` #### 操作触发器 1. **创建触发器** 创建触发器的基本语法如下(以 MySQL 为例): ```sql CREATE TRIGGER trigger_name BEFORE | AFTER {INSERT | UPDATE | DELETE} ON table_name FOR EACH ROW BEGIN -- 触发器逻辑 END; ``` 2. **删除触发器** 使用 `DROP TRIGGER` 语句可以删除一个触发器。 ```sql DROP TRIGGER IF EXISTS trigger_name; ``` 3. **启用或禁用触发器** 在 SQL Server 中,可以通过以下语句启用或禁用触发器: - **禁用触发器** ```sql DISABLE TRIGGER trigger_name ON table_name; ``` - **启用触发器** ```sql ENABLE TRIGGER trigger_name ON table_name; ``` 4. **触发器执行记录** 触发器本身不会直接提供修改了多少条记录的信息,但可以通过在触发器逻辑中添加日志记录或使用 `ROW_COUNT()` 函数(MySQL 中)来间接获取受影响的记录数。 ```sql SELECT ROW_COUNT(); ``` #### 示例:创建一个简单的触发器 以下是一个在 MySQL 中创建触发器的示例,当向表 `orders` 插入数据时,会自动更新另一个表 `order_log` 的日志记录。 ```sql DELIMITER // CREATE TRIGGER after_order_insert AFTER INSERT ON orders FOR EACH ROW BEGIN INSERT INTO order_log (order_id, log_message, log_time) VALUES (NEW.order_id, 'New order created', NOW()); END; // DELIMITER ; ``` ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值