加入收藏 | 设为首页 | 会员中心 | 我要投稿 厦门网 (https://www.xiamenwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

SQL – 如何比较CLOB

发布时间:2021-02-23 16:42:10 所属栏目:编程 来源:网络整理
导读:在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;

(编辑:厦门网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读