SQL – 如何比较CLOB
发布时间:2020-12-12 06:05:14 所属栏目:MsSql教程 来源:网络整理
导读:在DB2触发器中,我需要比较CLOB字段的值. 就像是: IF OLD_ROW.CLOB_FIELD != UPDATED_ROW.CLOB_FIELD 但“!=”不适用于比较CLOB. 比较它的方法是什么? 编辑添加: 如果在更新期间更改了Clob字段,我的触发器需要执行一些操作.这就是我需要比较触发器代码中的
在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; (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |