利用SQLLDR加载包含LOB对象的数据(三)

简单描述一下通过第二数据文件方式加载LOB类型的方法。

介绍更复杂的情况,数据文件中文件名和目录分别存储。

利用SQLLDR加载包含LOB对象的数据(一):http://yangtingkun.itpub.net/post/468/521873

利用SQLLDR加载包含LOB对象的数据(二):http://yangtingkun.itpub.net/post/468/521965

 

 

事实上,如果数据文件中文件名和目录是分开存储的,那么只利用SQLLDR是没有什么好办法解决这个问题的。

如果利用EXPRESSION来拼接目录和文件名,那么不管这个EXPRESSIONFILLER/BOUNDFILLER熟悉还是表中真实存在的列,都无法在LOAD LOB的时候提供正确的信息,因为EXPRESSION是通过SQL表达式生成,而LOAD LOB时,这个信息还没有生成。

如果真的这样做的话,会导致SEGMENTATION FAULT的错误,这篇文章已经详细了这个问题:http://yangtingkun.itpub.net/post/468/521911

那么是不是利用SQLLDR就没有办法了,其实也不是,不过不能只利用SQLLDR,而是采用以SQLLDR作为驱动的外部表的方法。

事实上外部表之所以可以直接这个功能,是因为外部表中不是简单的通过路径来读取LOB,而是通过DIRECTORY来实现。

这里给出一个简单的例子,当导入的目录比较固定时,可以通过下面的外部表方式导入:

SQL> CREATE TABLE T_EXTER_LOB
  2  (ID NUMBER,
  3  NAME VARCHAR2(80),
  4  DIRECTORY VARCHAR2(25),
  5  CONTENTS BLOB
  6  )
  7  ORGANIZATION EXTERNAL
  8  (TYPE ORACLE_LOADER
  9  DEFAULT DIRECTORY D_TEMP
 10  ACCESS PARAMETERS
 11  (RECORDS DELIMITED BY NEWLINE
 12  FIELDS TERMINATED BY ','
 13  (ID CHAR,
 14  DIRECTORY CHAR,
 15  NAME CHAR )
 16  COLUMN TRANSFORMS
 17  (CONTENTS FROM LOBFILE(CONSTANT 'D_DIR':NAME) FROM (D_DIR)))
 18  LOCATION ('TEMP.DAT'));

表已创建。

SQL> CREATE OR REPLACE DIRECTORY D_TEMP AS 'D:\TEMP';

目录已创建。

SQL> CREATE OR REPLACE DIRECTORY D_DIR AS 'D:\STUDY\YANGTK\OTHERS';

目录已创建。

对应的数据文件TEMP.DAT中数据为:

1,d:\study\yangtk\others,2006年总结.doc
2,d:\study\yangtk\others,2007Oracle
开发者大会(一).doc
3,d:\study\yangtk\others,2007Oracle
开发者大会(二).doc
4,d:\study\yangtk\others,2007
年总结.doc
.
.
.
74,d:\study\yangtk\others,
问题诊断和PLSQL方面.doc

下面利用CREATE TABLE AS SELECT的方式来加载数据:

SQL> CREATE TABLE T_LOAD_LOB
  2  AS SELECT * FROM T_EXTER_LOB;

表已创建。

SQL> SELECT ID, DIRECTORY, NAME FROM T_LOAD_LOB;

ID DIRECTORY NAME
---------- ------------------------- ------------------------------
         1 d:\study\yangtk\others    2006
年总结.doc
         2 d:\study\yangtk\others    2007Oracle
开发者大会(一).doc
         3 d:\study\yangtk\others    2007Oracle
开发者大会(二).doc
         4 d:\study\yangtk\others    2007
年总结.doc
.
.
.
        74 d:\study\yangtk\others    
问题诊断和PLSQL方面.doc

已选择74行。

检查加载日志,确认外部表加载成功:

日志文件打开于 08/14/11 23:13:26

T_EXTER_LOB 的字段定义
记录格式 DELIMITED BY NEWLINE
文件中的数据与该平台的 endianness 格式相同
接受带有空字段的行

数据源中的字段:

ID CHAR (255)
"," 终止
SQL 加载程序一样修剪空白
DIRECTORY CHAR (255)
"," 终止
SQL 加载程序一样修剪空白
NAME CHAR (255)
"," 终止
SQL 加载程序一样修剪空白

列转换
CONTENTS
LOBFILE 中设置
目录来自常数 D_DIR
忽略目录对象列表
文件来自字段 NAME
文件包含字符数据
在字符集 ZHS16GBK

最后通过全文索引验证BLOB字段加载成功:

SQL> CREATE INDEX IND_T_LOB_CONTENTS
  2  ON T_LOAD_LOB(CONTENTS) INDEXTYPE IS CTXSYS.CONTEXT;

索引已创建。

SQL> SELECT COUNT(*)
  2  FROM T_LOAD_LOB
  3  WHERE CONTAINS(CONTENTS, 'ORACLE') > 0;

COUNT(*)
----------
        52

 

 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/4227/viewspace-704831/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/4227/viewspace-704831/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值