Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1786348
  • 博文数量: 1647
  • 博客积分: 80000
  • 博客等级: 元帅
  • 技术积分: 9980
  • 用 户 组: 普通用户
  • 注册时间: 2008-10-13 15:15
文章分类

全部博文(1647)

文章存档

2011年(1)

2008年(1646)

我的朋友

分类:

2008-10-28 18:04:55

本文详细讲述了中对COLUMNS_UPDATED()返回值解析。

需求来源

客户要求[某些特定的表]能[自定义预警报告]。

(在特定的表上)用户可定义某些字段有修改时,向有关用户发出消息警报<内容大致是 xx 单据的 xx 单号的xx字段由 old 变为了 new>。最终目的是由消息控制模块向消息接收人报告这一变更。

基础知识:

COLUMNS_UPDATED()是一个仅可在 Insert or Update trigger 中调用的方法。

该方法返回 一个 varbinary 的值, 了当次Insert 或是Update 触发器所对应的记录在哪些字段上发生了Inserted or updated。在SQLSERVER 的联机帮助[CREATE TRIGGER]和[IF UPDATE] 中有对 COLUMNS_UPDATED () 方法的简要描述。

公司要求用Trigger 实现: (为每个[特定的表]编写一个特定的UPDATE 触发器。)主要难点是穷举IF UPDATE(column)的方法不可行。其它业务实现无问题。后来仔细琢磨COLUMNS_UPDATED() 所返回的值,问题得到解决。

这里只是讲述对COLUMNS_UPDATED()所返回的值的解析和运用,就不考虑用户指定变更字段及插入记录到消息表的那部分实现过程了。

数据准备

If exists(select * from sysobjects where 
id=object_id(N'[dbo].[T_Test]') and xtype = 'u')
DROP Table T_Test
go
CREATE Table T_Test (
f_idint IDENTITY(1, 1) Primary Key,
f_charChar(8) default '',
f_varchar  varchar(8) default '',
f_nvarchar  nvarchar(8) default '',
f_datetime  datetime default getdate(),
f_intint default 0,
f_bigint  bigint default 0,
f_decimal  decimal(18, 6) default 0.00,
f_number  numeric(18, 6) default 0.00,
f_floatfloat default 0.00
)
go
INSERT INTO T_Test (f_char) values('001')
INSERT INTO T_Test (f_char) values('002')
      go

 

[1]   

【责编:Peng】

--------------------next---------------------

阅读(240) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~