赞
踩
触发器是一种存储数据库过程,当数据库中发生特定事件(如插入、更新或删除操作)时,会自动调用该触发器。审核SQL Server实例的方法有很多,其中一种方法是使用审核触发器,触发器在SQL Server数据库中扮演着关键的角色,是执行业务规则、维护数据完整性和简化重复操作的不可或缺的工具。
SQL触发器是一种特殊类型的存储过程,它在指定的表中的数据发生变化时自动生效。触发器可以响应INSERT、UPDATE或DELETE语句,并在这些操作前后执行预定义的操作,如查询其他表、执行复杂的Transact-SQL语句等。触发器的执行不是由程序直接调用,而是由数据库事件触发。它们常用于加强数据完整性约束和业务规则的实现。
触发器的语法通常包括以下几个部分:
若要在 SQL Server 中创建触发器,请使用由以下元素组成的 CREATE TRIGGER 语句:
CREATE TRIGGER TriggerName
ON TableName
AFTER INSERT, UPDATE
AS
BEGIN
---SQL statements here---
END;
Drop TRIGGER TriggerName;
SHOW TRIGGERS
In database_ name;
CREATE TRIGGER [schema_name.]trigger_name
ON table_name
AFTER INSERT
AS
BEGIN
-- Insert your trigger logic here.
-- Specify the SQL statements to be executed upon trigger activation.
END
在这里,schema_name指定触发器的模式,如果没有提供,则使用默认模式(通常是dbo)。接下来,trigger_name是触发器的名称,table_name是触发器操作的表的名称,AFTER INSERT指定应该在向表中插入行之后调用触发器。SQL Server不像其他数据库系统那样支持BEFORE INSERT触发器。接下来,开始…END包含了定义触发器功能的SQL语句。这个块可以包含复杂的逻辑,包括调用其他过程、将数据插入到其他表中等等。
触发器有四种类型:
DDL 触发器为响应 DDL 事件而触发,CREATE、ALTER、DROP、GRANT、DENY 和 REVOKE Transact-SQL 语句可以调用 DDL 触发器。调用的 DDL 触发器可以执行以下功能之一:
DML 触发器是在执行 DML 语句(如 INSERT、UPDATE 和 DELETE)时执行的过程。这些触发器通过自动创建名为 INSERTED 和 DELETED 的表来帮助进行审核,以记录修改数据库之前和之后的值。
DML 触发器根据其执行时间分为两种类型:
CLR 触发器允许管理员在 SQL Server 实例中创建具有 SQL Server 环境外部引用对象的对象,这是一种特殊类型的触发器,可以直接插入到 .NET 语言代码中,并且在 SQL Server 2008 及更高版本中可用。
发生 SQL Server LOGON 事件时,将触发登录触发器,登录触发器可用于跟踪登录活动、控制登录尝试以及限制对关键 SQL Server 实例的登录。
触发器是SQL Server中的一个强大功能,可以自动执行任务、执行业务规则和维护数据完整性。但是,由于它们对数据库性能和复杂性的潜在影响,应该谨慎使用它们。以下是有效利用触发器的一些关键指导方针:
尽管使用触发器审计 SQL Server 在某种程度上是有效的,但是这种方法有很大的局限性,只能为单个表创建触发器。因此,如果有 100 个需要监控的表,管理员则需要创建 100 个触发器,这是一个主要的操作瓶颈。创建审核触发器所需的时间和精力是相当可观的,这意味着审核不能仅仅依赖于触发器。手动审核数据库的管理员应仔细考虑选择 SQL Server。此外,SQL Server 触发器记录的信息不会提供对 SQL Server 环境中可能发生的事件或攻击的见解。
除了使用 SQL 触发器之外,还可以采用其他方法,例如SQL Trace和 SQL Server Profiler、数据库审计规范、服务器审计规范以及命令和控制审计。或者,可以使用日志管理解决方案(如EventLog Analyzer)来有效地审SQL Server日志。
EventLog Analyzer是一种有效的日志管理解决方案,可收集所有SQL Server日志,并为数据库中发生的所有 DDL、DML 和安全相关事件提供直观的报告。它可以为特权滥用、敏感数据泄露、帐户锁定、存储介质暴露、SQL 注入和 DoS 攻击等关键事件提供报告,管理员可以为这些事件设置警报,以便通过电子邮件和短信实时通知。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。