交友约会| 杂志期刊| 小说| 论坛| 电影下载| 两性知识| 电脑知识| 汽车| 旅游| 收藏

Oracle中对COLUMNS_UPDATED()返回值解析

来源:赛迪网 作者: 出处:综艺读书 2007-06-13 进入讨论组
关 键 词:存储  oracle  
下一页 1 2 3 

本文详细讲述了Oracle中对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

  更多文章 更多内容请看Oracle 10g基础应用专题,或进入讨论组讨论。

下一页 1 2 3 
收藏此文】【 】【打印】【关闭
相关图文阅读
频道图文推荐
综艺读书宗旨
相关专题
·Oracle 10g基础应用 (4022篇文章)
热点标签: 存储  oracle  
最新技术文档
站内各频道最新更新文档
站内最新制作专题
热门关键字导读
Photoshop教 程照片处理 照片制作 PS快捷键 抠图
计 算 机 故 障XP系统修复
艺 术 与 设 计设计 流媒体 设计欣赏 边框
计 算 机 安 全ARP
站内频道文章精选
百度推荐,商机无限
搜索您感兴趣的内容
Web 全站
综艺电脑频道编辑信箱  告诉我们您想看的专题或文章

友情互链 | 收藏本站 | 联系我们 | 在线留言 | 京ICP备08008424号|