当前位置: 首页 > java >正文

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;

六、使用触发器的注意事项

http://www.xdnf.cn/news/18854.html

相关文章:

  • defineCustomElement 的局限性及重载需求分析
  • Ubuntu 虚拟机配置 Git 并推送到Gitee
  • 如何利用Claude在商业项目中进行自动化客户反馈分析:一站式解决方案
  • 【R代码分析】甲烷排放绘制代码-参考论文
  • Unity游戏打包——Mac基本环境杂记
  • 实时平台Flink热更新技术——实现不停机升级!
  • 从16个粉丝到680万年收入:AI创业的117天奇迹
  • 负载均衡之带权重的随机负载均衡算法详解与实现
  • 迷你版Shell:源码详解与行为解析
  • S-HUB实现泛微E9与飞书对接
  • kafka消费顺序保障
  • 【车载开发系列】CS+ for CC开发环境IDE
  • Flask模块如何使用
  • HIDL的Car Audio架构简单梳理
  • 《2025年Windows最新最细IDE激活码永久破解教程 – 支持JetBrain全家桶2099年授权》
  • 电脑快速关机工具,一键重启休眠
  • Debian Buster 软件源失效问题
  • vue2+elementui 表格单元格增加背景色,根据每列数据的大小 颜色依次变浅显示2
  • zookeeper-保姆级配置说明
  • 深度学习篇---ResNet-18网络结构
  • 【算法--链表题1】2. 两数相加:通俗详解
  • 用大语言模型实现语音到语音翻译的新方法:Scheduled Interleaved Speech-Text Training
  • 论文Review 激光3DGS GS-SDF | IROS2025 港大-MARS!| 激光+3DGS+NeRF会得到更好的几何一致性和渲染结果!?
  • React前端开发_Day1
  • Linux虚拟机ansible部署
  • OSPF 的工作过程、Router ID 机制、报文结构
  • Axios多实例封装
  • 产品运营必备职场通用能力及提升攻略,一文说明白
  • Kafa面试经典题--Kafka为什么吞吐量大,速度快
  • 字帖生成器怎么用?电脑手机双端操作指南