Asp.Net教程,WinForm教程,Asp.Net MVC,vs2008教程,vs2010教程,Silverlight技术,源码下载,Asp.Net视频教程
全站热门标签
vs2010 Silverlight 存储过程 水晶报表 ADO.NET JavaScript LINQ AjaxPro DataGridView 面向对象 Extjs GridView XML DevExpress HTML教程 Oracle jQuery 分页 GDI+ Visual C++2010 MySQL Office2010 WPF MVC Dojo WCF4.0 VB.NET Sql2005 textbox cookie WCF WinForm Discuz!NT SQL经典语句 T-SQL checkbox ASPxGridView F# asp.net SQL VS2008新特性 DropDownList Access TreeView Ajax VS2008 页面执行时间 Flex 字符串 回调 VB2005 DataSet C#时间 ASP.NET性能优化 用户在线检测 动画
SQL Server Oracle Access MySQL
当前位置: 主页 > 数据库 > SQL Server >

触发器实例-trigger

时间:2010-01-15 21:19来源:未知 作者:admin 点击:

在许多应用中,需要保存某个数据表的历史记录,以供以后查询,在 SQL Server 2000中,可以利用触发器轻松实现历史记录功能。

 在触发器中,需要用到 SQL Server 的 inserted 和 deleted 两个虚拟表,在执行SQL命令时,这两个虚拟表分别记录的内容如下:
 
  sql命令       deleted               inserted
 ---------------------------------------------------
  insert        [不可用]             新插入的记录
  update     被更新前的记录         被更新后的记录
  delete      被删除的记录             [不可用]
 ---------------------------------------------------


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

 例如:
 
 当前有一个数据表 table1, 有 field1, field2, field3 三个字段。
 
 现在我们需要在 table1 发生变化(插入,修改,删除)时,记录下每次改动的情况。
 
 这只需要通过如下两个步骤就可以实现:
 
 
 1) 创建一个新表 table1_log, 用于记录 table1 的历史数据。
 
  table1_log 有如下字段:
 
  field1, field2, field3, sqlcomm (varchar 10), exectime (datetime)
 
  这比 table1 多了 sqlcomm, exectime 两个字段,分别记录 sql 语句的 insert,
 
  update, delete 命令和命令执行的时间)
 
 
 
 2) 在表 table1 上增加触发器,以在 table1 发生变动时,自动写入 table1_log.
 
 
  -- 针对 insert 命令,增加名为 trTable1_I 的触发器:
 
  -------------------------------- trTable1_I ----------------------------
  IF EXISTS (SELECT * FROM dbo.sysobjects
  WHERE id = object_id(N'[trTable1_I]')
  AND OBJECTPROPERTY(id, N'IsTrigger') = 1)
  DROP TRIGGER [trTable1_I]
  GO
 
  CREATE TRIGGER trTable1_I
  ON table1
  AFTER insert
  AS

  if @@rowcount = 0 --如果影响的行数为 0,则结束触发器运行,避免占用资源
      return
   
  insert into table1_log (field1, field2, field3, sqlcomm, exectime)
  select field1, field2, field3, 'insert', {fn NOW()} from inserted
 
  go
  -------------------------------- end trTable1_I -----------------------
 
 
  -- 针对 update 命令,增加名为 trTable1_U 的触发器:
 
  -------------------------------- trTable1_U ----------------------------
  IF EXISTS (SELECT * FROM dbo.sysobjects
  WHERE id = object_id(N'[trTable1_U]')
  AND OBJECTPROPERTY(id, N'IsTrigger') = 1)
  DROP TRIGGER [trTable1_U]
  GO
 
  CREATE TRIGGER trTable1_U
  ON table1
  AFTER update
  AS

  if @@rowcount = 0 --如果影响的行数为 0,则结束触发器运行,避免占用资源
      return
   
  insert into table1_log (field1, field2, field3, sqlcomm, exectime)
  select field1, field2, field3, 'update', {fn NOW()} from inserted
 
  go
  -------------------------------- end trTable1_U -----------------------
 
 
  -- 针对 delete 命令,增加名为 trTable1_D 的触发器:
 
  -------------------------------- trTable1_D ----------------------------
  IF EXISTS (SELECT * FROM dbo.sysobjects
  WHERE id = object_id(N'[trTable1_D]')
  AND OBJECTPROPERTY(id, N'IsTrigger') = 1)
  DROP TRIGGER [trTable1_D]
  GO
 
  CREATE TRIGGER trTable1_D
  ON table1
  AFTER delete
  AS

  if @@rowcount = 0 --如果影响的行数为 0,则结束触发器运行,避免占用资源
      return
   
  insert into table1_log (field1, field2, field3, sqlcomm, exectime)
  select field1, field2, field3, 'delete', {fn NOW()} from deleted
 
  go
  -------------------------------- end trTable1_D -----------------------
  
  
 在查询分析器中运行以上代码,以后 table1 发生的变化都会记录在 table1_log 表中了.

(责任编辑:admin)
Tags:
责任编辑:admin
返回顶部
------分隔线----------------------------
推荐内容
骆驼户外男 真皮磨砂日常休闲鞋 低帮 2011秋冬新款 专柜正品特价 骆驼户外男 真皮磨砂日常休闲鞋 低帮 2011秋冬新款 专柜正品特价
  • 数据库中自定义拆分字符串函数Split()

    经常我们要用到批量操作时都会用到字符串的拆分,郁闷的是SQL Server中却没有自带Split函数,所以我们只能自己动手来解决一下。为了减少和数据库的通讯次数...

  • sql函数实现三种父子递归

    在实际运用中经常会创建这样的结构表Category(Id, ParentId, Name),特别是用于树形结构时(菜单树,权限树..),这种表设计自然而然地会用...

  • SQL CASE WHEN使用

    Case具有两种格式。简单Case函数和Case搜索函数。 --简单Case函数 CASE sex WHEN '1' THEN '男' WHEN '2' THE...

  • MSSQL移除字符串两边的指定字符

    移除字符串左边的字符: CREATE FUNCTION [ dbo ] . [ RemoveLeftChar ] ( @Expression varchar (...

  • IDENTITY的小技巧--SQL Server 2005

    备份数据库遇到一个问题,就是将旧数据搬移到新主机数据表的时候,如果主键是的 IDENTITY 是设定自动增加的话,那么旧有的主键数据,在新数据表上面就好像是重新...

  • Sql2005将相同值的行内容进行合并

    如何将相同键值的蓝位内容值串接 ? 举例来说 TableA 如下: ID Type DESC 1 cpu 处理器 1 cpu 双核心 1 cpu 800外频 2...

  • SQL Server数据库恢复案例分享

    很多数据恢复工程师包括一些数据恢复技术爱好者经常会问同样一个问题:数据一旦被覆盖了,还能不能恢复呀?我听说国外能恢复被覆盖以后的数据,据说只要是覆盖操作在7次以...

  • SQL2005索引优化

    SQL2005索引优化...

  • 容易忽略的SQL语句

    容易忽略的SQL语句...

  • 世界完全对称日(SQL)

    世界完全对称日(SQL)...

  • 经典的sql语句技巧

    1、应用程序中,保证在实现功能的基础上,尽量减少对数据库的访问次数;通过 搜索参数,尽量减少对表的访问行数,最小化结果集,从而减轻网络负担;能够分 开的操作尽量...

  • provider:SQL网络接口, error: 26-定位指定的服务器/实例时出错

    在建立与服务器的连接时出错。在连接到 SQL Server 2005 时,在默认的设置下 SQL Server 不允许进行远程连接可能会导致此失败。 (prov...

  • 树形数据汇总查询(MS-SQL Server应用实例)

    -- SQL2000: -- 查询的数据语句: SELECT DISTINCT B.KJND,B.GSDM,A.FZDM,A.FZMC, ZBZE1 = SUM...

  • SQLServer批量备份与还原

    备份与还原是数据库避不开的主题,而作为DBA,经常会面临将一台机器上的所有数据库重新构建到一台新机器上的要求; 在现在都讲究自动化管理的时代,传统的界面操作备份...

  • 如何修改SQL Server 2005服务器名称

    1、使用SELECT @@ServerName可以看到当前数据库的服务器名 2、SELECT * FROM Sys.SysServers表中可以看到当前的所有服...