Какой самый быстрый способ извлечь 100К изображений из базы данных Oracle? - PullRequest
0 голосов
/ 18 января 2011

Варианты, о которых я думаю:

1) C # Консольное приложение для извлечения изображений в файловую систему Windows.

2) Java-приложение для извлечения изображений в файловой системе на основе Unix.

Любой другой метод, который вы можете придумать, пожалуйста, дайте мне знать. Имеется приблизительно 101 234 записи, и каждый столбец BLOB может иметь файл от 1 до 6 МБ.

1 Ответ

1 голос
/ 18 января 2011

Если вам нужна скорость, я бы порекомендовал вам использовать хранимую процедуру PL / SQL для непосредственного сохранения изображений в файлы. Должно быть быстрее, чем внешняя программа

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 ('TEMPDIR', 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;

Проверьте это Ссылка

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...