当前位置:  开发笔记 > 编程语言 > 正文

处理Oracle分布式数据库中LOB的最佳方法

如何解决《处理Oracle分布式数据库中LOB的最佳方法》经验,为你挑选了2个好方法。

如果创建Oracle dblink,则无法直接访问目标表中的LOB列.

例如,您使用以下命令创建dblink:

create database link TEST_LINK 
  connect to TARGETUSER IDENTIFIED BY password using 'DATABASESID';

在此之后,您可以执行以下操作:

select column_a, column_b 
from data_user.sample_table@TEST_LINK

除非列是LOB,否则会出现错误:

ORA-22992: cannot use LOB locators selected from remote tables

这是一个记录在案的限制.

同一页面建议您将值提取到本地表中,但这有点麻烦:

CREATE TABLE tmp_hello 
AS SELECT column_a 
from data_user.sample_table@TEST_LINK

还有其他想法吗?



1> 小智..:

使用如下查询的最佳解决方案,其中column_b是BLOB:

SELECT (select column_b from sample_table@TEST_LINK) AS column_b FROM DUAL



2> hamishmcn..:

是的,它很乱,我想不出一种避免它的方法.
您可以通过将临时表创建放在存储过程中来隐藏客户端的一些混乱(并使用"立即执行"来创建它们的表)
您需要注意的一件事是留在临时表(如果出现故障)在您有时间清理它之前的一半会话中 - 您可以安排oracle作业定期运行并删除任何剩余的表.

推荐阅读
sx-March23
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有