blob是oracle中的一个数据类型,保存的是压缩后的二进制形式的大数据。
数据迁移如果涉及到blob字段,都不好处理,因为无法用常规方法进行操作,如:使用select查看该字段,也无法用insert插入该字段的值。
以下记录了blob字段的导出、导入方法流程。
方法原理:利用UTL_FILE将blob字段的内容以二进制的形式导出到txt文档,然后用dbms_blob将文档内容导入到指定的数据库表中
1、创建一个文本文档来保存blob数据
这里在home目录下创建了一个名为test.txt的文件,即/home/dhl/test.txt
2、创建oracle临时目录
create or replace directory UTL_FILE_DIR as ‘/home/dhl/’;
3、导出blob数据
这里以SY_QRTZ_JOB_DETAILS这张数据表为例子,其中的JOB_DATA就是blob类型的字段
DECLARE
file_handle UTL_FILE.FILE_TYPE;
b_lob BLOB;
BEGIN
select JOB_DATA into b_lob from SY_QRTZ_JOB_DETAILS where JOB_NAME=‘2WNfkfZZ14YUodhnYOfEzbl’;
file_handle := utl_file.fopen(‘UTL_FILE_DIR’, ‘test.txt’, ‘W’);
utl_file.PUT_RAW(file_handle , b_lob, true);
UTL_FILE.FCLOSE(file_handle);
END;
4、将文档内容导入到指定的数据库表中
DECLARE
b_file bfile;
b_lob BLOB;
BEGIN
–return a into b_lob将该列与一个blog类型的变量绑定在一起,以后只要为b_lob赋值,即等于将该值插入了表中
INSERT
INTO SY_QRTZ_JOB_DETAILS
(
SCHED_NAME,
JOB_NAME,
JOB_GROUP,
DESCRIPTION,
JOB_CLASS_NAME,
IS_DURABLE,
IS_NONCONCURRENT,
IS_UPDATE_DATA,
REQUESTS_RECOVERY,
JOB_DATA
)
VALUES
(
‘RhScheduler’,
‘test6’,
‘DEFAULT’,
‘test6’,
‘com.rh.core.icbc.imp.NImpStateJob’,
‘1’,
‘0’,
‘0’,
‘0’,
empty_blob()
)
RETURN JOB_DATA
INTO b_lob;
–将文件转换为bfile
b_file := bfilename(‘UTL_FILE_DIR’, ‘test.txt’);
dbms_lob.open(b_file, dbms_lob.file_readonly);
– 将b_file中的内容转换到b_lob
dbms_lob.loadfromfile(b_lob,b_file,dbms_lob.getlength(b_file));
dbms_lob.close(b_file);
COMMIT;
END;