详细分析SQL Server触发器的基本知识

前言

原先写过一篇类似的,不过是基于Mysql:添加链接描述

对应Sql Server的补充知识点:详细配置SQL Server的链接服务器(图文操作Mysql数据库)

1. 基本知识

基本知识其实差不多,先从CRUD开始

触发器的类型:

  • DML触发器:在对表进行插入、更新或删除操作时触发
    AFTER触发器:在操作完成后执行
    INSTEAD OF触发器:代替操作执行,操作本身不会发生
  • DDL触发器:在对数据库对象进行创建、修改或删除时触发
  • LOGON触发器:在用户登录到数据库时触发

触发器的作用

  • 数据验证:在数据修改前或后执行额外的验证逻辑
  • 审计记录:记录数据的变更历史
  • 自动计算:基于表中的数据自动计算其他值

2. Demo

创建触发器:

CREATE TRIGGER trigger_name
ON table_name
[AFTER | INSTEAD OF] {INSERT | UPDATE | DELETE}
AS
BEGIN
    -- 触发器逻辑
END;

增加触发器:

CREATE TRIGGER trg_AfterInsert
ON Employees
AFTER INSERT
AS
BEGIN
    INSERT INTO AuditLog (Action, LogDate, EmployeeID)
    SELECT 'INSERT', GETDATE(), EmployeeID
    FROM inserted;
END;

更新触发器:

CREATE TRIGGER trg_InsteadOfUpdate
ON Employees
INSTEAD OF UPDATE
AS
BEGIN
    -- 执行自定义的更新逻辑
    UPDATE Employees
    SET Name = inserted.Name
    FROM inserted
    WHERE Employees.EmployeeID = inserted.EmployeeID;
END;

查看触发器:

SELECT * 
FROM sys.triggers 
WHERE parent_id = OBJECT_ID('table_name');

删除触发器:

DROP TRIGGER trigger_name;

3. 查找特定表的存储过程

  • 查询当前数据库中的所有存储过程
SELECT name 
FROM sys.procedures;

在这里插入图片描述

  • 通过表名查询触发器:

使用sys.sql_modules视图和OBJECT_DEFINITION函数

SELECT OBJECT_NAME(object_id) AS ProcedureName
FROM sys.sql_modules
WHERE OBJECT_DEFINITION(object_id) LIKE '%YourTableName%';

在这里插入图片描述

多加一个字段属性,可以给出详细的存储过程的定义

SELECT 
    OBJECT_NAME(m.object_id) AS ProcedureName,
    m.definition AS ProcedureDefinition
FROM 
    sys.sql_modules m
WHERE 
    OBJECT_DEFINITION(m.object_id) LIKE '%ags.GateReservationDetail%';

在这里插入图片描述

  • 通过触发器名称查询:
    如果有多个名称,都可在in后面进行添加补充
SELECT 
    OBJECT_NAME(m.object_id) AS ProcedureName,
    m.definition AS ProcedureDefinition
FROM 
    sys.sql_modules m
WHERE 
    OBJECT_NAME(m.object_id) IN ('View_JobOwner');

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码农研究僧

你的鼓励将是我创作的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值