前言
原先写过一篇类似的,不过是基于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');
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |