PL/SQL 사용 파일의 내용을 블로브로 어떻게 얻습니까?
문제
파일이 있습니다. 내 컨텐츠를 Oracle 데이터베이스의 Blob 열이나 PL/SQL 프로그램의 Blob 변수로 가져오고 싶습니다. 그렇게하는 가장 좋은 방법은 무엇입니까?
해결책
PL/SQL에서 전적으로 수행하려면 파일은 데이터베이스에서 정의 해야하는 디렉토리에 위치한 서버에 있어야합니다. 다음 객체를 만듭니다.
CREATE OR REPLACE DIRECTORY
BLOB_DIR
AS
'/oracle/base/lobs'
/
CREATE OR REPLACE PROCEDURE BLOB_LOAD
AS
lBlob BLOB;
lFile BFILE := BFILENAME('BLOB_DIR', 'filename');
BEGIN
INSERT INTO table (id, your_blob)
VALUES (xxx, empty_blob())
RETURNING your_blob INTO lBlob;
DBMS_LOB.OPEN(lFile, DBMS_LOB.LOB_READONLY);
DBMS_LOB.OPEN(lBlob, DBMS_LOB.LOB_READWRITE);
DBMS_LOB.LOADFROMFILE(DEST_LOB => lBlob,
SRC_LOB => lFile,
AMOUNT => DBMS_LOB.GETLENGTH(lFile));
DBMS_LOB.CLOSE(lFile);
DBMS_LOB.CLOSE(lBlob);
COMMIT;
END;
/
다른 팁
환경에 약간 의존합니다. Java에서는 이런 식으로 할 수 있습니다 ...
// Need as OracleConnection in mConnection
// Set an EMPTY_BLOB()
String update = "UPDATE tablename"+
" SET blob_column = EMPTY_BLOB()"+
" WHERE ID = "+id;
CallableStatement stmt = mConnection.prepareCall(update);
stmt.executeUpdate();
// Lock the row FOR UPDATE
String select = "BEGIN " +
" SELECT " + blob_column
" INTO ? " +
" FROM " + tablename +
" WHERE ID = '" + id + "'" +
" FOR UPDATE; " +
"END;";
stmt = mConnection.prepareCall(select);
stmt.registerOutParameter(1, java.sql.Types.BLOB);
stmt.executeUpdate();
BLOB blob = (BLOB) stmt.getBlob(1);
OutputStream bos = blob.setBinaryStream(0L);
FileInputStream fis = new FileInputStream(file);
// Code needed here to copy one stream to the other
fis.close();
bos.close();
stmt.close();
mConnection.commit();
그러나 실제로 사용하는 환경 / 도구에 달려 있습니다. 더 많은 정보가 필요합니다.
제휴하지 않습니다 StackOverflow