1、先为数据库建立一个字段试图,所有数据都是从系统表中提取,便于以后用户可以扩展系统功能。
CREATE VIEW dbo.V_SystemColumn
AS
SELECT DISTINCT
TOP 100 PERCENT dbo.sysobjects.name AS TableName, dbo.sysobjects.id,
dbo.sysobjects.xtype, dbo.syscolumns.name AS ColumnName,
dbo.syscolumns.colid, dbo.syscolumns.type, dbo.syscolumns.colstat
FROM dbo.sysobjects INNER JOIN
dbo.syscolumns ON dbo.sysobjects.id = dbo.syscolumns.id
WHERE (dbo.sysobjects.xtype = 'U')
ORDER BY dbo.sysobjects.id, dbo.syscolumns.colid
2、建立一个各个表之间关联的视图。
CREATE VIEW dbo.V_Reference
AS
SELECT DISTINCT
TOP 100 PERCENT o1.name AS PK_TABLE_NAME, c1.name AS PK_COLUMN_NAME,
o2.name AS FK_TABLE_NAME, c2.name AS FK_COLUMN_NAME
FROM dbo.sysobjects o1 INNER JOIN
dbo.sysreferences r ON o1.id = r.rkeyid INNER JOIN
dbo.syscolumns c1 ON o1.id = c1.id AND r.rkey1 = c1.colid INNER JOIN
dbo.sysobjects o2 ON r.fkeyid = o2.id INNER JOIN
dbo.syscolumns c2 ON o2.id = c2.id AND r.fkey1 = c2.colid INNER JOIN
dbo.sysindexes i ON r.rkeyid = i.id AND r.rkeyindid = i.indid
WHERE (permissions(o1.id) <> 0) AND (permissions(o2.id) <> 0)
ORDER BY FK_Table_Name
3、创建一个存取过程,参数为:表名、列名、Insert.列名的值、返回参数
CREATE Procedure GetColumnValue
@FKTableName Varchar(128),
@FKColumnName Varchar(128),
@FKValue Varchar(8000),
@ReturnValue Varchar(8000) OUTPUT
AS
declare @PkTableName Varchar(128)
declare @PkColumnName Varchar(128)
declare @PkDescriptionName Varchar(128)
declare @SqlText Varchar(8000)
declare @ret varchar(8000)
--获取关联主表的表名和字段名
select @PkTableName=Pk_Table_Name,@PkColumnName=Pk_Column_Name from V_Reference
Where FK_Table_Name=@FKTableName and
FK_Column_Name=@FKColumnName
if(@PkTableName is null)
begin
Select @ReturnValue=@FKValue
return 0
end
else
begin
Select Top 1 @PkDescriptionName=ColumnName
from V_SystemColumn
Where TableName=@PkTableName and ColumnName like '%Name'
Create Table #temp
(PkDescriptionName Varchar(8000) )
select @SqlText=' Insert Into #temp Select '+@PkDescriptionName
select @SqlText=@SqlText+' from '+@PkTableName
select @SqlText=@SqlText+' Where '+@PkColumnName+'='+''''+@FKValue+''''
execute(@SqlText)
select @ReturnValue=PkDescriptionName from #temp
end
GO
4、为系统创建记录日志的表
CREATE TABLE T_SystemLog (
TableName varchar(128) NULL,
KeyValue varchar(20) NOT NULL,
FieldName varchar(128) NULL,
OldValue varchar(8000) NULL,
NewValue varchar(8000) NULL,
Modifier varchar(20) NULL,
ModifyDate datetime NULL DEFAULT CURRENT_TIMESTAMP
)
go
5、创建日志记录存取过程
CREATE Procedure Logger
@TableName Varchar(128),
@ColumnName Varchar(128),
@KeyValue int,
@OldValue Varchar(8000),
@NewValue Varchar(8000),
@LastModifier Varchar(20)
AS
if(@OldValue<>@NewValue)
begin
exec GetColumnValue @TableName,@ColumnName,@OldValue,@OldValue Output
exec GetColumnValue @TableName,@ColumnName,@NewValue,@NewValue Output
Insert Into T_SystemLog(TableName,KeyValue,FieldName,OldValue,NewValue,Modifier,ModifyDate)
Values( @TableName,@KeyValue,@ColumnName,@OldValue,@NewValue,@LastModifier,getdate())
end
GO
6、为需要记录修改日志的表创建Insert、Update触发器
CREATE trigger uti_corp on T_Corp
for Update
AS
set nocount on
declare @KeyValue int
declare @OldValue Varchar(8000)
declare @NewValue varchar(8000)
declare @LastModifier varchar(8000)
if(update(departmentid))
begin
select @KeyValue=corpid,@NewValue=departmentid,@LastModifier=LastModifier from inserted
select @OldValue=departmentid from deleted
execute Logger 'T_Corp','DepartmentID',@KeyValue,@OldValue,@NewValue,@LastModifier
end
分享到:
相关推荐
在很多应用场景中,为了确保数据完整性及可追溯性,我们往往需要记录数据表中的历史变更信息,以便于日后审计或数据分析。例如,在银行系统中,对账户余额的任何更改都需要被记录下来,以便追踪资金流动情况;在电商...
【触发器生成数据库表操作日志】是一种技术手段,用于记录数据库中特定数据表的DML(数据操作语言)变化,如INSERT、DELETE和UPDATE操作。这种做法在数据库管理中非常常见,尤其对于审计和追踪数据变更历史至关重要...
通过触发器,可以记录每次对表的操作详情,包括操作类型、受影响的表名、改动的时间以及具体更改的数据。这有助于跟踪和审计数据库的变化,对于故障排查和数据分析非常有用。 4. SQL Server的sysmessages表: 这...
本篇文章将详细介绍如何在SQL Server中创建一个触发器,当某个表中的特定字段被更新时,记录相关信息到另一个表中,以实现类似日志记录的功能。 #### 触发器概述 触发器是SQL Server提供的一种机制,可以在表或视图...
在Oracle 8i/9i版本中,由于内置的审计功能仅能记录谁执行了操作,但无法详细展示数据的变化情况,因此触发器成为了实现细粒度审计的关键手段。 触发器的创建主要涉及以下步骤和类型: 1. DDL(Data Definition ...
触发器是SQL Server数据库管理系统中的一个重要概念,它是一种特殊类型的存储过程,主要用于在数据库中发生数据修改事件(如INSERT、UPDATE、DELETE)时自动执行预定义的SQL语句。触发器可以用来维护数据的完整性和...
为了应对这类问题,可以通过创建Oracle系统触发器来实现对`DROP TABLE`和`TRUNCATE TABLE`命令的监控与阻止。以下详细介绍两种不同的Oracle版本(10g和8i)下如何创建相应的系统触发器。 ### Oracle 10g环境下的...
这种业务需求,我们可以通过数据库的触发器来轻松实现历史记录功能。 本文以SQL Server 2005数据库中的触发器为例(因为手中的项目用的就是这个数据库) 先简单描述一下SQL Server触发器。 SQL Server触发器的...
总结起来,基于Oracle存储过程与触发器的三维空间数据日志管理方法是一种实用的技术手段,它结合了数据库的内建功能,实现了高效、安全的数据日志管理,特别适合于需要精确记录和监控操作的三维空间数据应用场景。...
在数据复制场景中,触发器可以用来捕获这些变更,并将它们记录到一个称为重做日志(Redo Log)的结构中。重做日志是复制的关键组件,因为它包含了数据库变更的完整历史,可以用于将变更传播到其他复制站点。 **4. ...
触发器特别适用于确保数据一致性,例如在多表之间进行复杂的业务逻辑联动更新,或者在数据修改前后执行特定的审计操作。 在日志管理中,触发器可以在数据操作执行前后自动记录相关信息,如操作时间、操作用户、操作...
数据库触发器是数据库管理系统中的一种重要机制,它允许在数据修改(INSERT、UPDATE或DELETE)时执行特定的SQL代码或存储过程。SQL触发器的概念源自关系数据库理论,用于实现复杂的数据完整性约束,或者在数据发生...
- `sys.fn_dblog` 函数可用于查看事务日志,这在创建审计触发器时尤其重要,可以追踪到每一个数据修改的详细信息。 - `sys.fn_get_audit_file` 可以获取审计文件内容,帮助分析和报告触发器的活动。 5. **触发器...
- **审计跟踪**:使用触发器记录数据更改的时间戳、用户等信息,以便进行审计跟踪。 - **级联操作**:在执行某些操作时自动执行相关的其他操作,如更新相关表中的记录。 总之,触发器作为一种强大的工具,在确保...
例如,After UPDATE触发器可以用于更新关联表中的统计数据,或记录数据更改的历史记录。 #### DML触发器与替代触发器 - **DML触发器**:这类触发器可在数据操纵语言(DML)操作前或后触发,适用于单个行或整个语句...
总结来说,C#中利用Update触发器记录系统日志,可以帮助我们更好地监控数据变动,同时提供了一种在数据库层面进行数据审计的方法。结合C#代码和数据库触发器,可以实现一个完整的日志管理系统,提高应用程序的稳定性...
触发器可以用于实现复杂的业务规则,如数据验证、审计日志记录和数据转换等。 ### 二、SQL语句创建触发器 #### 1. 前触发器(BEFORE TRIGGER) 前触发器是在数据修改操作实际发生之前执行的。这使得触发器有机会...