码迷,mamicode.com
首页 > 数据库 > 详细

Oracle通过DBLink访问CLOB类型字段报错ORA-22992的解决方案

时间:2020-02-03 17:22:18      阅读:317      评论:0      收藏:0      [点我收藏+]

标签:两种   hang   acl   比较   时间   transform   过多   通过   使用   

DBLink 中,对于普通字段按常规方法查询即可,但是对于 CLOB 字段的处理相对比较麻烦, CLOB 为大字段,通常 VARCHAR 最大只支持到 4000 字符。在按常规方法查询时会有以下结果:

SELECT MODE_CODE,TRANSFORM_CHANGE_CONTENT from TABLE@ DBLINK ,其中 “TRANSFORM_CHANGE_CONTENT” 为 CLOB 字段,会报 “ORA-22992: cannot use LOB locators selected from remote tables” 的错误。

常规的处理方法有以下两种:

1.      采用临时表方式实现对 LOB 字段的选取: 
创建一个临时表 “create global temporary table TMP_TB( 
MODE_CODE VARCHAR2(16), 
TRANSFORM_CHANGE_CONTENT CLOB 
)on commit delete rows;” , 
再执行 “INSERT INTO TMP_TB SELECT MODE_CODE,TRANSFORM_CHANGE_CONTENT from TABLE@ DBLINK;” 后,临时表中就将对应的数据选取过来了,最后再通过执行 “SELECT * from TMP_TB;” ,即可查看到结构。

2.      采用将 CLOB 转换为 VARCHAR 的方式实现: 
首先需要用到函数 “dbms_lob.substr( clob_column, for_how_many_bytes, from_which_byte );” 
通过创建如下视图: 
CREATE OR REPLACE VIEW DBLINK_V AS 
  SELECT MODE_CODE, dbms_lob.substr(TRANSFORM_CHANGE_CONTENT,4000,1) TRANSFORM_CHANGE_CONTENT 
    FROM TABLE 
通过执行 “SELECT MODE_CODE,TRANSFORM_CHANGE_CONTENT from DBLINK_V @DBLINK;” ,即可实现查看到结果

结论,方法 1 中也可以使用普通表,但使用的临时表效率要高于普通表,这里不做过多讨论;方法 2 中创建视图的效率要远高于方法 1 ,时间上看方法 1 大于方法2 的几倍左右。

Oracle通过DBLink访问CLOB类型字段报错ORA-22992的解决方案

标签:两种   hang   acl   比较   时间   transform   过多   通过   使用   

原文地址:https://www.cnblogs.com/nietzsche2019/p/11274728.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!