• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    利用SQL Server触发器实现表的历史修改痕迹记录

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

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

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

    SQL Server触发器的inserted和deleted

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

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

    SQL操作 inserted表 deleted表
    增加(insert)记录 存放新增的记录 [不可用]
    修改(update)记录 存放更新后的记录 存放更新前的记录
    删除(delete)记录 [不可用] 存放被删除的记录

    SQL Server触发器的instead of和after

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

    说(复制)了这么多,是因为我们要实现的功能需要用到inserted虚拟表、deleted虚拟表和after触发器。

    实现方法

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

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

    CREATE TABLE product(name VARCHAR(50),description VARCHAR(200),unit_cost MONEY,pub_time DATETIME)
    GO

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

    1.创建日志表

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

    CREATE TABLE product_log(name VARCHAR(50),description VARCHAR(200),unit_cost MONEY,pub_time DATETIME,sqlcomm varchar(10),exectime datetime)
    GO

    新增的两个字段sqlcomm和exectime分别记录执行命令(insert、update和delete)和执行时间

    2.增加触发器

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

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

    CREATE TRIGGER tr_product_i
    ON product
    AFTER INSERT
    AS
    if @@rowcount = 0 --为了避免占用资源,当影响行数为0时,结束触发器
     return
    insert into product_log (name,description,unit_cost,pub_time,sqlcomm,exectime)
     select name,description,unit_cost,pub_time,'insert',getdate() from inserted
    GO

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

    CREATE TRIGGER tr_product_u
    ON product
    AFTER UPDATE
    AS
    if @@rowcount = 0 --为了避免占用资源,当影响行数为0时,结束触发器
     return
    /*更新前*/
    insert into product_log (name,description,unit_cost,pub_time,sqlcomm,exectime)
     select name,description,unit_cost,pub_time,'update',getdate() from deleted
    /*更新后*/
    insert into product_log (name,description,unit_cost,pub_time,sqlcomm,exectime)
     select name,description,unit_cost,pub_time,'update',getdate() from inserted
    GO

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

    CREATE TRIGGER tr_product_d
    ON product
    AFTER DELETE
    AS
    if @@rowcount = 0 --为了避免占用资源,当影响行数为0时,结束触发器
     return
    insert into product_log (name,description,unit_cost,pub_time,sqlcomm,exectime)
     select name,description,unit_cost,pub_time,'delete',getdate() from deleted
    GO

    3.测试触发器

    插入(insert)测试

    INSERT INTO product(name,description,unit_cost,pub_time)
     VALUES('逗比','这是一个逗比的测试数据',200.5,'1990-11-18')
    GO
    
    SELECT * FROM product
    SELECT * FROM product_log
    GO

    更新(update)测试

    UPDATE product SET unit_cost=250.0 WHERE name='逗比'
    GO
    
    SELECT * FROM product
    SELECT * FROM product_log
    GO

    删除(delete)测试

    DELETE FROM product WHERE name='逗比'
    GO
    
    SELECT * FROM product
    SELECT * FROM product_log
    GO

    好了这篇文章就介绍到这了,需要的朋友可以参考一下。

    您可能感兴趣的文章:
    • 关于喜忧参半的SQL Server触发器详解
    • SQLSERVER对加密的存储过程、视图、触发器进行解密(推荐)
    • SQL Server 使用触发器(trigger)发送电子邮件步骤详解
    • SQL Server实现用触发器捕获DML操作的会话信息【实例】
    • SQL Server:触发器实例详解
    • SqlServer触发器详解
    • SqlServer实现类似Oracle的before触发器示例
    • SQL SERVER中各类触发器的完整语法及参数说明
    • SQL SERVER 触发器介绍
    • SQL Server误区30日谈 第4天 DDL触发器就是INSTEAD OF触发器
    • SQL Server 触发器详情
    上一篇:数据库常用的sql语句汇总
    下一篇:SQL语句执行超时引发网站首页访问故障问题
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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