UTL_FILE.FOPEN()如何声明和分配目录路径?

时间:2017-03-10 05:36:59

标签: plsql oracle-sqldeveloper

我有这个代码使用toad从Oracle数据库中提取图像,但是当我说出提取后保存图像的目录时,我遇到了挑战。我希望这些图像保存在本地计算机的C:\ Images \ a文件夹中。这是可能的,或者我应该如何指定目录?。

当我执行代码时获得Invalid file operation

DECLARE
t_blob BLOB;
t_len NUMBER;
t_file_name VARCHAR2(100);
t_output UTL_FILE.file_type;
t_TotalSize number;
t_position number := 1;
t_chucklen NUMBER := 4096;
t_chuck raw(4096);
t_remain number;
BEGIN
-- Get length of blob
SELECT DBMS_LOB.getlength (PHOTO), ename || '_1.jpg'
INTO t_TotalSize, t_file_name FROM DEMO WHERE ENAME ='moon';
t_remain := t_TotalSize;
-- The directory TEMPDIR should exist before executing
t_output := UTL_FILE.fopen ('C:\Images\', t_file_name, 'wb', 32760);
-- Get BLOB
SELECT PHOTO INTO t_blob FROM DEMO WHERE ENAME ='moon';
-- Retrieving BLOB
WHILE t_position < t_TotalSize
LOOP
DBMS_LOB.READ (t_blob, t_chucklen, t_position, t_chuck);
UTL_FILE.put_raw (t_output, t_chuck);
UTL_FILE.fflush (t_output);
t_position := t_position + t_chucklen;
t_remain := t_remain - t_chucklen;
IF t_remain < 4096
THEN
t_chucklen := t_remain;
END IF;
END LOOP;
END;

2 个答案:

答案 0 :(得分:0)

你应该使用DIRECTORY对象,

create or replace directory my_dir as 'c:\Images\';

declare
v_dir varchar2(10) := 'MY_DIR';
.....
begin
....
t_output := utl_file.fopen(v_dir, t_file_name, 'wb', 32760);
....

答案 1 :(得分:0)

首先要知道,当您执行任何处理文件的PL / SQL脚本时,它总是执行到运行oracle实例的服务器的范围内。

在这种情况下,路径“C:\ Image \”需要存在于Oracle运行的服务器上。

您可以使用的一种策略是将脚本执行到服务器的文件夹中,然后通过终端/控制台上的“复制命令”获取文件夹数据。