触发器简单使用

有一个用户表tbUsers,有好多fields,我只关注其中几个,nUserID,sUserName,sPassword;我希望有人对这数据更新,插入以及删除时能够自动记录入另一个表tbUsersActions。我使用了SQL触发器。

create trigger 用户更新触发器 on tbUsers for updateas insert into tbUsersActions(id,name,pwd,dCreateDate,action)select inserted.nUserID,inserted.sUserName,inserted.sPassword,getDate(),'update' from inserted Create trigger 用户插入触发器 on tbUsers for insertasinsert into tbUsersActions(id,name,pwd,dCreateDate,action)selectinserted.nUserID,inserted.sUserName,inserted.sPassword,getDate(),'insert' frominserted create trigger 用户删除触发器 on tbUsers for deleteasinsert into tbUsersActions(id,name,pwd,dCreateDate,action)selectdeleted.nUserID,deleted.sUserName,deleted.sPassword,getDate(),'delete' from deleted 


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQL触发器是一种特殊的数据库对象,它可以在数据库中的表上自动执行特定的操作,例如插入、更新或删除数据时触发其他操作。触发器通常用于实现数据的完整性约束、日志记录和数据同步等功能。 SQL触发器的语法如下: ```sql CREATE TRIGGER trigger_name {BEFORE | AFTER} {INSERT | UPDATE | DELETE} ON table_name [FOR EACH ROW] [WHEN (condition)] BEGIN -- 触发器操作 END; ``` 其中,关键字解释如下: - `CREATE TRIGGER`:用于创建一个触发器。 - `trigger_name`:触发器的名称,需在数据库中唯一。 - `BEFORE | AFTER`:指定触发器在触发点之前或之后执行。 - `INSERT | UPDATE | DELETE`:指定触发器在插入、更新或删除操作时触发。 - `table_name`:指定触发器所属的表名。 - `FOR EACH ROW`:可选项,表示每行触发,即每次操作影响的行都会触发触发器。 - `WHEN (condition)`:可选项,指定触发器的条件,只有满足条件时触发器才会执行。 - `BEGIN` 和 `END`:用于定义触发器的操作区块。 在触发器的操作区块中,可以编写任意的SQL语句,包括查询、更新等操作。触发器可以访问当前操作的行的值,可以使用`NEW`关键字引用插入或更新的新行,使用`OLD`关键字引用删除或更新之前的旧行。 以下是一个简单的示例,演示了一个在`orders`表中插入新订单时触发的触发器: ```sql CREATE TRIGGER order_trigger AFTER INSERT ON orders FOR EACH ROW BEGIN -- 向日志表插入一条记录 INSERT INTO orders_log (order_id, action, action_date) VALUES (NEW.order_id, 'INSERT', NOW()); END; ``` 上述示例中,`order_trigger`是触发器的名称,`orders`是触发器所属的表名。每次在`orders`表中插入一条新记录时,触发器会向`orders_log`表中插入一条相应的日志记录。 需要注意的是,触发器使用需要谨慎,不当的使用可能导致性能问题或产生意外的结果。因此,在使用触发器时,建议仔细考虑触发器的设计和操作,确保其符合业务需求,并进行充分的测试和验证。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值