SQL server 触发器的使用
在 SQL Server 中,触发器(Trigger) 是一种特殊的存储过程,它在对表执行 INSERT、UPDATE 或 DELETE 操作时自动触发执行,无需手动调用。它常用于数据验证、审计日志、级联更新、同步数据等场景。
一、触发器的类型(SQL Server)
二、触发器的基本语法
CREATE TRIGGER trigger_name
ON table_name
[WITH ENCRYPTION]
FOR | AFTER | INSTEAD OF
[INSERT, UPDATE, DELETE]
AS
BEGINSET NOCOUNT ON;-- 触发器逻辑-- 可使用 INSERTED 和 DELETED 逻辑表
END
三、关键概念:INSERTED 和 DELETED 逻辑表
触发器通过两个临时逻辑表获取变更数据:
四、常见使用场景与示例
-- 目标:当 user_account 表有更新时,记录变更到 log 表CREATE TRIGGER tr_user_account_update_log
ON user_account
AFTER UPDATE
AS
BEGINSET NOCOUNT ON;INSERT INTO account_log (user_id, old_balance, new_balance, change_time, operation)SELECT d.user_id,d.balance AS old_balance,i.balance AS new_balance,GETDATE(),'UPDATE'FROM DELETED dJOIN INSERTED i ON d.id = i.id;
END
场景 2:同步数据到另一张表
-- 目标:当 BBD_FANLI_LS 有新返利插入时,同步到 BBD_FLZHBDTX 提醒表CREATE TRIGGER tr_BBD_FANLI_LS_SyncToNotice
ON BBD_FANLI_LS
AFTER INSERT
AS
BEGINSET NOCOUNT ON;INSERT INTO BBD_FLZHBDTX (user_id, order_no, amount, tx_time)SELECT user_id, order_no, rebate_amount, rebate_timeFROM INSERTED;
END
场景 3:数据验证与限制
-- 目标:禁止删除状态为 '已完成' 的订单CREATE TRIGGER tr_order_delete_check
ON orders
INSTEAD OF DELETE
AS
BEGINSET NOCOUNT ON;IF EXISTS (SELECT 1 FROM DELETED WHERE status = '已完成')BEGINRAISERROR('无法删除已完成的订单!', 16, 1);ROLLBACK TRANSACTION;RETURN;ENDELSEBEGINDELETE FROM orders WHERE id IN (SELECT id FROM DELETED);END
END
场景 4:级联更新(替代外键级联)
-- 目标:当用户姓名更改时,自动更新相关订单中的客户名CREATE TRIGGER tr_user_update_cascade
ON users
AFTER UPDATE
AS
BEGINSET NOCOUNT ON;UPDATE oSET customer_name = i.nameFROM orders oJOIN INSERTED i ON o.user_id = i.idJOIN DELETED d ON i.id = d.idWHERE i.name <> d.name; -- 仅当姓名变化时更新
END
五、触发器的管理
-- 查看某表上的触发器
SELECT * FROM sys.triggers WHERE parent_id = OBJECT_ID('your_table');-- 查看触发器定义
EXEC sp_helptext 'trigger_name';-- 查看所有触发器(排除系统自带的触发器)SELECT t.name AS TriggerName,OBJECT_NAME(t.parent_id) AS TableName,t.type_desc AS TriggerType, -- DML or DDLt.create_date,t.modify_date,t.is_disabled
FROM sys.triggers t
WHERE t.is_ms_shipped = 0 -- 排除系统自带的触发器
ORDER BY t.create_date DESC;-- 禁用
DISABLE TRIGGER tr_user_account_update_log ON user_account;-- 启用
ENABLE TRIGGER tr_user_account_update_log ON user_account;-- 删除触发器DROP TRIGGER tr_user_account_update_log;
六、使用触发器的注意事项