Полезное для программистов:

Фриланс
Новости
Статьи
   
Рубрики:


Запись в файл на клиенте.

Поиск:
Иногда возникает необходимость записать данные в файл, а возможностей UTL_FILE нехватает. В таком случае можно воспользоваться хранимыми процедурами на Java.

1. Создаем Java class
Код
create or replace and compile java source named write_to_client as
import java.io.*;
import java.sql.*;

public class NetWrite
{
  public static void writeToFile(String file, Blob data) throws Exception
  {
    FileOutputStream out = new FileOutputStream(file);
    InputStream in = data.getBinaryStream();
    int read;
    byte[] buffer = new byte[16 * 1024];
    while((read = in.read(buffer)) != -1)
      out.write(buffer, 0, read);
    in.close();
    out.close();
  }
}
/

2. Создаем процедуру на PL/SQL
Код
create or replace procedure WRITE_CLIENT(file varchar2, data blob) as
language java name 'NetWrite.writeToFile(java.lang.String, java.sql.Blob)';

3. Выдаем разрешения на чтение и запись любого файла (при желании, можно ограничить процедуру записью, лишь в некоторые файлы/директории)
Код
begin
  sys.dbms_java.grant_permission('PUBLIC', 'java.io.FilePermission', '<<ALL FILES>>', 'read,write');
end;
/

4. Проверяем
Код
declare 
  bin_data blob;
begin
  select photo_data into bin_data from photos where id = 'D490AA09AEF3424A9AEEFAAC638B283E';
  write_client('C:\TEMP\foto.jpeg', bin_data);
end;
/
Автор: LSD






Просмотров: 4234

 

 

Новые статьи:


Популярные:
  1. Как сделать цикличным проигрывание MIDI-файла?
  2. Создание AVI файла из рисунков
  3. Как устройство "отключить в данной конфигурации"?
  4. Kто в данный момент присоединен через Сеть?
  5. Как узнать количество доступной памяти?
  6. Как реализовать в RichEdit разноцветный текст?
  7. Как скрыть свое приложение от ProcessViewer
  8. Как программно нажать/скрыть/показ кнопку "Start"?
  9. Модуль работы с ресурсами в PE файлах
10. Функции вызова диалоговых окон выбора
11. Проверка граматики средствами Word'а из Delphi.
12. Модуль для упрощенного вызова сообщений
13. Функции для записи и чтение своих данных в, ЕХЕ- файле
14. Рекурсивный просмотр директорий
15. Network Traffic Monitor
16. Разные модули
17. Универсальная функция для обращения к любым экспортируем функциям DLL
18. Библиотека от VladS
19. Протектор для UPX'а
20. Еще об ICQ, сообщения по контакт листу?
21. Использование открытых интерфейсов
22. Теория и практика использования RTTI
23. Работа с TApplication
24. Примеры использования Drag and Drop для различных визуальных компонентов
25. Что такое порт? Правила для работы с портами
26. Симфония на клавиатуре
27. Загрузка DLL
28. Исправление автоинкремента
29. Взаимодействие с чужими окнами
30. Проверить дубляжи в столбце


 

 

 
 
На главную