Oracle中对COLUMNS_UPDATED()返回值解析
2007-06-15 12:33:29 来源:WEB开发网核心提示:本文详细讲述了Oracle中对COLUMNS_UPDATED()返回值解析,需求来源客户要求[某些特定的表]能[自定义预警报告],Oracle中对COLUMNS_UPDATED()返回值解析,(在特定的表上)用户可定义某些字段有修改时,向有关用户发出消息警报<内容大致是 xx 单据的 xx 单号的xx字段由 ol
本文详细讲述了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 恢复误删除的表和误更新的表
- ››Oracle分页查询排序数据重复问题
- ››Oracle创建dblink报错:ORA-01017、ORA-02063解决
- ››Oracle 提高SQL执行效率的方法
- ››Oracle 动态查询,EXECUTE IMMEDIATE select into...
- ››Oracle 11g必须开启的服务及服务详细介绍
- ››oracle性能34条优化技巧
- ››oracle数据库生成随机数的函数
- ››Oracle 数据库表空间容量调整脚本
- ››oracle单库彻底删除干净的方法
- ››Oracle创建表空间、创建用户以及授权、查看权限
- ››oracle 中 UPDATE nowait 的使用方法
更多精彩
赞助商链接