最近第一次接触触发器,感觉很是新奇,也很是蛋疼,因为老板要求的是在触发器中获取用户信息,并把对表的操作进行记录,后者实现到时比较简单,前者确实让我纠结了好久,其实百度了一下关于SQL2008触发器的文章还是挺多的,写的好的也有好几篇,不过我觉得还是要根据自己的理解再给广大网友分享一下,从初识、理解、到最后的使用。

首先来看一下触发器的语法:

USE [数据库名]
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
创建或修改(CREATE|ALTER) TRIGGER 触发器名(最好以XXXX_TR命名规范结尾)
ON
表名
FOR 对于什么操作触发(Insert,Update,Delete )
AS
BEGIN
触发后要做的操作
end

讲到触发器,当然少不了要提一下Inserted和Deleted表,

Deleted 与Inserted分别表示触发事件的表“旧的一条记录”和“新的一条记录”。一个数据库系统中有两个虚拟表用于存储在表中记录改动的信息,分别是:

           虚拟表Inserted                     虚拟表Deleted

在表记录新增时       存放新增的记录                         不存储记录

修改时              存放用来更新的新记录                   存放更新前的记录

删除时              不存储记录                             存放被删除的记录

一个Insert 的过程可以看作为:生成的记录到Inserted表,

一个Delete的过程可以看作为:生成的记录到Deleted表,

一个Update 的过程可以看作为:生成新的记录到Inserted表,复制旧的记录到Deleted表

这两个表在触发器中很是重要,一定要理解和区分 他们的关系和作用!

这两个表的结构和触发器对应的表结构是相同的!

在贴出我的关于删除触发的触发器实例供大家参考:

 USE [pd]
GO
/****** Object: Trigger [dbo].[table_delete] Script Date: 06/10/2014 09:39:20 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
create TRIGGER [dbo].[DayRunRecord20140528_delete]
ON [dbo].[DayRunRecord20140528]
after delete
AS
if @@rowcount = 0 --如果影响的行数为 0,则结束触发器运行,避免占用资源
begin
return
end
else
BEGIN
SET NOCOUNT ON;
DECLARE @OperateDate datetime;
DECLARE @IPAddreass VARCHAR(20);
DECLARE @HostName varchar(50);
DECLARE @loginame varchar(50);
DECLARE @content varchar(5000)
DECLARE @content_temp varchar(2000)
DECLARE @OperateTable varchar(50);
--获取用户新增内容(人员定位表的字段)
DECLARE @ID int;
DECLARE @MineNumber int;
DECLARE @PepoleNumber int;
DECLARE @RouteStation varchar(10);
DECLARE @RouteTime datetime;
DECLARE @DataFlag int;
DECLARE @Remark1 char(50);
DECLARE @WorkNumber varchar(50);
DECLARE @ReceiveTime datetime;
DECLARE @EnterFlag int;
DECLARE @PowerFlag int;
DECLARE @DeviceDbId int;
DECLARE @TR_LastUpdateTime datetime;
DECLARE @TR_GUID uniqueidentifier;
set @content = '';
--声明游标
declare myCursor Cursor for
SELECT * from deleted
open myCursor
fetch next from myCursor into @ID,@MineNumber,@PepoleNumber,@RouteStation,@RouteTime,@DataFlag,@Remark1,@WorkNumber,@ReceiveTime,@EnterFlag,@PowerFlag,@DeviceDbId,@TR_LastUpdateTime,@TR_GUID
WHILE (@@FETCH_STATUS = 0)
BEGIN
set @content_temp = 'ID='+Convert(varchar,@ID) +
';MineNumber='+Convert(varchar,@MineNumber)+
';PepoleNumber='+Convert(varchar,@PepoleNumber)+
';RouteStation='+ @RouteStation +
';RouteTime='+Convert(varchar,@RouteTime)+
';DataFlag='+Convert(varchar,@DataFlag)+
';Remark1='+Convert(varchar,@Remark1) +
';WorkNumber='+@WorkNumber+
';ReceiveTime'+Convert(varchar,@ReceiveTime)+
';EnterFlag='+Convert(varchar,@EnterFlag)+
';PowerFlag='+Convert(varchar,@PowerFlag)+
';DeviceDbId='+Convert(varchar,@DeviceDbId)+
';TR_LastUpdateTime='+Convert(varchar,@TR_LastUpdateTime)+
';TR_GUID='+CONVERT(varchar(36),@TR_GUID);
if(@content<>'')
begin
set @content = @content + '&' +@content_temp ;
end
else
begin
set @content = @content_temp ;
end
--将游标下移
FETCH NEXT FROM myCursor into @ID,@MineNumber,@PepoleNumber,@RouteStation,@RouteTime,@DataFlag,@Remark1,@WorkNumber,@ReceiveTime,@EnterFlag,@PowerFlag,@DeviceDbId,@TR_LastUpdateTime,@TR_GUID
END
--关闭游标
CLOSE myCursor
--释放游标
DEALLOCATE myCursor
set @OperateTable = 'DayRunRecord20140528';
set @IPAddreass = convert(varchar,CONNECTIONPROPERTY('client_net_address'));
set @HostName = CONVERT(varchar,HOST_NAME());
set @OperateDate = GETDATE();
set @loginame = CONVERT(varchar,(select system_user));
--为日志表添加数据
insert into XJK_USER_OperateLog(OperateType,OperateTable,OperateContent,OperateDate,IPAddreass,HostName,UserName)
values('删除',@OperateTable,@content,@OperateDate,@IPAddreass,@HostName,@loginame);
END

其实代码虽然多,里面实现的功能却很简单,就是遍历Deleted表中删除的内容,并把这些内容拼接到一个变量中,用于记录成一个日志。

SQL2008触发器的更多相关文章

  1. 捕获Insert触发器失败记录

    1.背景 环境:发布服务器A Windows2008+SQL2008,分发服务器B Windows2008+SQL2008,订阅服务器C Windows2008+SQL2012发布服务器A上的用户信息 ...

  2. SQL2008--SQL语句-存储过程-触发器-事务处理-基本语法-函数

    环境 SQL2008 1.存储过程建立 库-可编程性-存储过程-右击“存储过程”-点击“新建存储过程” SET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGOCRE ...

  3. SQL触发器批量删除数据库中的表

    以下通过触发器批量删除数据库中的表,SQL2008已验证 DECLARE @Table NVARCHAR() DECLARE @Count Int = DECLARE tmpCur CURSOR FO ...

  4. sql2008破解加密存储过程

    网上的很多不能正确解密,出现空白,还好有这个,mark下了. Create PROCEDURE [dbo].[sp_windbidecrypt] (@procedure sysname = NULL, ...

  5. 【读后感1】SQL2008技术内幕- SQL逻辑查询处理

    引言观点 1. 编程语言日新月异,但是从没有人否定sql 在现代编程中的巨大作用和 持续的可利用性.SQL以对人类友好的阅读体验提供数据查询能力( 相比其他编程语言 ), 同时在各种数据库平台中,基础 ...

  6. 在SQL2008查找某数据库中的列是否存在某个值

    在SQL2008查找某数据库中的列是否存在某个值 --SQL2008查找某数据库中的列是否存在某个值 create proc spFind_Column_In_DB ( @type int,--类型: ...

  7. pt-online-schema-change中update触发器的bug

    pt-online-schema-change在对表进行表结构变更时,会创建三个触发器. 如下文测试案例中的t2表,表结构如下: mysql> show create table t2\G . ...

  8. MySQL主从环境下存储过程,函数,触发器,事件的复制情况

    下面,主要是验证在MySQL主从复制环境下,存储过程,函数,触发器,事件的复制情况,这些确实会让人混淆. 首先,创建一张测试表 mysql),age int); Query OK, rows affe ...

  9. MySQL 系列(三)你不知道的 视图、触发器、存储过程、函数、事务、索引、语句

    第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 第三篇:MySQL 系列(三)你不知道的 视图.触发器.存储过程.函数 ...

随机推荐

  1. vim - copy/paste a word

    1. http://stackoverflow.com/questions/7797068/copying-a-word-and-pasting-over-a-word viwp - visually ...

  2. 新上市Lighthouse专用芯片TS3633规格介绍

    背景介绍 Valve 有远大的愿景.它决心要把 SteamVR 追踪系统推向世界,从虚拟现实里的空间定位,到机器人领域,Valve 想为各种环境下的跟踪应用提供支持. 上个月,Valve 方面宣布会把 ...

  3. 通过Chrome浏览器检测和优化页面

    1.访问(http://www.cnblogs.com/viaiu/) 2.点击F12 前两步就在扯淡 3.点击Audits标签,进入测试界面 4.点击按钮开始检测 5.如下图可以进行页面加载资源的详 ...

  4. iOS之在webView中引入本地html,image,js,css文件的方法 - sky//////////////////////////////////////ZZZZZZZZZZZZZZZ

    iOS之在webView中引入本地html,image,js,css文件的方法   2014-12-08 20:00:16CSDN-sky_2016-点击数:10292     项目需求 最近开发的项 ...

  5. linux系统无法启动解决方案

    windows和linux双系统一般先安装Windows,分两个主分区,把Linux安装在另外的主分区上.Linux编译内核,添加NTFS分区支持,然后Mount NTFS 分区即可访问Windows ...

  6. Qt4.8.5在ARM9上的移植

    Qt4.8.5在ARM9开发板上的移植 以前移植过qtopia-embedded-2.2.0,俗称Qt/E,在早期的Qt框架中是使用X11桌面服务器系统,无法应用于嵌入式平台,为此产生了qtopia, ...

  7. XiangBai——【AAAI2017】TextBoxes_A Fast Text Detector with a Single Deep Neural Network

    XiangBai--[AAAI2017]TextBoxes:A Fast Text Detector with a Single Deep Neural Network 目录 作者和相关链接 方法概括 ...

  8. SVD java 算法实现

    https://github.com/Richard-Cao/MatrixSvdDemo/blob/master/app/src/main/java/me/ele/caolicheng/matrixs ...

  9. 优化 bulk insert

    https://www.simple-talk.com/sql/learn-sql-server/bulk-inserts-via-tsql-in-sql-server/

  10. 学习了quartz.net2.0的心得

    由于项目中要运用到此调度方法,所以抽空学习了下,简单的用法可以掌握了 首先作为没有用过的人来说,怎么用呢? 于是百度了下原来先要下载 quartz.net2.0, 然后我就去下了个quartz.net ...