在DB2触发器中,我需要比较CLOB字段的值.
就像是:
就像是:
IF OLD_ROW.CLOB_FIELD != UPDATED_ROW.CLOB_FIELD
但“!=”不适用于比较CLOB.
比较它的方法是什么?
编辑添加:
如果在更新期间更改了Clob字段,我的触发器需要执行一些操作.这就是我需要比较触发器代码中的2个CLOB的原因.
我正在寻找有关如何做到这一点的一些详细信息
解决方法
在Oracle 10g中,您可以使用DBMS_LOB.compare()API.
例:
select * from table t where dbms_lob.compare(t.clob1,t.clob2) != 0
完整的API:
DBMS_LOB.COMPARE ( lob_1 IN BLOB,lob_2 IN BLOB,amount IN INTEGER := 4294967295,offset_1 IN INTEGER := 1,offset_2 IN INTEGER := 1) RETURN INTEGER; DBMS_LOB.COMPARE ( lob_1 IN CLOB CHaraCTER SET ANY_CS,lob_2 IN CLOB CHaraCTER SET lob_1%CHARSET,offset_2 IN INTEGER := 1) RETURN INTEGER; DBMS_LOB.COMPARE ( lob_1 IN BFILE,lob_2 IN BFILE,amount IN INTEGER,offset_2 IN INTEGER := 1) RETURN INTEGER;
原文地址:https://www.jb51.cc/mssql/83981.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。