简单描述一下通过第二数据文件方式加载LOB类型的方法。
介绍更复杂的情况,数据文件中文件名和目录分别存储。
利用SQLLDR加载包含LOB对象的数据(一):http://yangtingkun.itpub.net/post/468/521873
利用SQLLDR加载包含LOB对象的数据(二):http://yangtingkun.itpub.net/post/468/521965
事实上,如果数据文件中文件名和目录是分开存储的,那么只利用SQLLDR是没有什么好办法解决这个问题的。
如果利用EXPRESSION来拼接目录和文件名,那么不管这个EXPRESSION是FILLER/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/