I created a table with a key_value and Bfile column. Create a directory alias. Insert a row using the BFILENAME procedure. I said 1 row added. Tried to execute the PL/SQL code below. I get an "nonexistent directory or file error on Open". What is wrong and how can I determine I insert a record there something in the BFILE column?
DECLARe
FILE_LOC BFILE;
BUFFER RAW(1024);
AMOUNT BINARY_INTEGER := 25000;
POSITION INTEGER := 1;
BEGIN
/*SELECT THE LOB */
SELECT picture_LOb INTO FILE_LOC
FROM LOB_PICTURES_TABLE
WHERE KEY_VAULE = 1;
/* OPENING THE BFILE */
DBMS_LOB.OPEN (FILE_LOC, DBMS_LOB.LOB_READONLY);
LOOP
DBMS_LOB.READ(FILE_LOC, AMOUNT, POSITION, BUFFER);
/* DISPLAY THE BUFFER CONTENTS */
DBMS_OUTPUT.PUT_LINE(UTL_RAW.CAST_TO_VARCHAR2(BUFFER));
POSITION := POSITION + AMOUNT;
END LOOP;
/* CLOSE BFILE */
DBMs_LOB.CLOSE (FILE_LOC);
EXCEPTION
WHEN NO_DATA_FOUND THEN
DBMS_OUTPUT.PUT_LINE('END OF DATA');
End;
Software/Hardware used:
ASKED:
June 26, 2006 2:37 PM
UPDATED:
June 27, 2006 11:16 AM