利用SQL Server触发器实现表的历史修改痕迹记录

  

在很多应用程序开发中,需要记录某些数据表的历史记录或修改痕迹,以便日后出现数据错误时进行数据排查。这种业务需求,我们可以通过数据库的触发器来轻松实现历史记录功能。

  

本文以SQL Server 2005数据库中的触发器为例(因为手中的项目用的就是这个数据库)

  

<强>先简单描述一下SQL Server触发器。

  

SQL Server触发器的插入和删除

  

SQL Server为每个触发器都创建了两个专用虚拟表:插入表和删除表。这两个表由系统来维护,他们存在于内存中,而不是在数据库中,这两个表的结构总是与被该触发器作用的表结构相同。触发器执行完成后,与该触发器相关的两个表会被删除(即在内存中销毁)。

  

插入表存放由执行插入或更新语句而要想飙中插入的所有行,即:插入后或更新后的值。
  删除表存放由删除或更新语句而要从表中删除的所有行,即:删除或更新钱的值。

  

           SQL操作   插入表   删除表               增加(插入)记录   存放新增的记录   (不可用)         修改(更新)记录   存放更新后的记录   存放更新前的记录         删除(删除)记录   (不可用)   存放被删除的记录            

  

<强> SQL Server触发器后的代替和

  

SQL Server提供了两种触发器:而不是和后触发器。这两种触发器的区别在于他们被激活的时机不同:

  
      <李>而不是触发器用于替代引用触发器执行的sql语句。除表之外,而不是触发器也可以用于视图,用来扩展视图可以支持更新操作。   <李>后触发器在一个插入、更新或删除语句之后执行,进行约束检查等动作都触后在发器被激活之前发生后触发器只能用于数据表中。   
  

说(复制)了这么多,是因为我们要实现的功能需要用插入到虚拟表,删除虚拟表和后触发器。

  

<>强实现方法

  

通过一个示例来演示具体的实现方法。

  

假设当前有一个表:产品表(产品),字段为“产品名(名)”,“产品描述(描述)”,“单价(unit_cost)”和“生成日期(pub_time)”。

  
  

创建表的产品(名称VARCHAR(50),描述VARCHAR (200), unit_cost钱,pub_time DATETIME)
  去

     

现在我们“上帝”的需求的是:需要记录产品表发生数据变化(增、删、改)时,记录每次操作改动情况。

  

<强> 1。创建日志表

  

需要创建一个产品日志表(product_log)用来将记录每次数据改动情况,我这里直接在原数据表的结构上增加两个字段(在实际开发环境中,大家可以根据需求来设置日志表的表结构),分别为sqlcomm和exectime;代码如下:

        创建表product_log(名称VARCHAR(50),描述VARCHAR (200), unit_cost钱,pub_time DATETIME, sqlcomm VARCHAR (10), exectime DATETIME)   之前去      

新增的两个字段sqlcomm和exectime分别记录执行命令(插入、更新和删除)和执行时间

  

<强> 2。增加触发器

  

在产品表增加触发器,其目的是为了记录表数据发生改变时记录到product_log中。

  

针对插入(插入)操作,增加名为tr_product_i的触发器:

        创建触发器tr_product_i   在产品   后插入   作为   如果@@rowcount=0,为了避免占用资源,当影响行数为0时,结束触发器   返回   插入product_log(名称、描述unit_cost、pub_time sqlcomm, exectime)   选择名称、描述unit_cost pub_time,“插入”,获取当前日期从插入()   之前去      

针对更新(更新)操作,增加名为tr_product_u的触发器:

        创建触发器tr_product_u   在产品   后更新   作为   如果@@rowcount=0,为了避免占用资源,当影响行数为0时,结束触发器   返回/*更新前*/插入product_log(名称、描述unit_cost、pub_time sqlcomm, exectime)   选择名称、描述unit_cost pub_time,“更新”,获取当前日期()删除/*更新后*/插入product_log(名称、描述unit_cost、pub_time sqlcomm, exectime)   选择名称、描述unit_cost pub_time,“更新”,获取当前日期从插入()   之前去      

针对删除(删除)操作,增加名为tr_product_d的触发器:

        创建触发器tr_product_d   在产品   后删除   作为   如果@@rowcount=0,为了避免占用资源,当影响行数为0时,结束触发器   返回   插入product_log(名称、描述unit_cost、pub_time sqlcomm, exectime)   选择名称、描述unit_cost pub_time,“删除”,获取当前日期()删除   

利用SQL Server触发器实现表的历史修改痕迹记录