Форум программистов, компьютерный форум, киберфорум
Visual C++: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
3 / 3 / 2
Регистрация: 13.10.2009
Сообщений: 102

Как прочитать блоб из БД в файл без использования системной таблицы pg_largeobject?

10.01.2019, 20:42. Показов 2528. Ответов 0

Студворк — интернет-сервис помощи студентам
Есть таблица table с колонками oid integer, id integer и data bytea
Мне нужно записать бинарный файл в пользовательскую таблицу table а так же прочитать его из таблицы в файл.
Записываю таким оразом:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
FILE *file;
const char *filename("../test/database.db");
if((file=fopen(filename, "r"))==NULL)
{
perror("ошибка при открытии файла \n");
exit(0);
}
struct stat _buf;
stat(filename, &_buf); // заполнить структуру stat информацией о файле с названием filename
size_t size = _buf.st_size; // достать размер файла из структуры stat
Oid lo_id;
int lo_fd;
char buf[size];
int nbytes, tmp;
int fd;
char *quer = new char[100];
res = PQexec(conn, "begin");
PQclear(res);
fd = open(filename, O_RDONLY); // открытие файла для чтения
lo_id = lo_creat(conn, INV_READ | INV_WRITE); //создание блоба
lo_fd = lo_open(conn, lo_id, INV_WRITE); //открытие блоба
    
if((nbytes = read(fd, buf, size)) > 0) // чтение файла и запись содержимого в буфер
{
tmp = lo_write(conn, lo_fd, buf, nbytes); // запись буфера в базу данных в системную таблицу pg_largeobject
if(tmp<nbytes)
{
printf("error of read blob \n");
}
sprintf(quer,  "insert into table (oid, id, data) values (%d, %d, '%s::bytea')",lo_id,  1, buf);
res = PQexec(conn,  quer); // запись блоба в пользовательскую таблицу table
if(PQresultStatus(res) == PGRES_TUPLES_OK)
{
printf("ok exec_insert..\n");
} else {
 cout << "res = "<< PQresultErrorMessage(res) << endl;
}
}
close(fd);
lo_close(conn, lo_fd);
fclose(file);
res = PQexec(conn, "end");
PQclear(res);

Достаю блоб из базы данных и записываю в файл:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
char *query = new char[100];
sprintf(query,  "select oid, id, data from table where id = 1"); //достаю информацию из пользовательской таблицы
res = PQexec(conn,  query);
if(PQresultStatus(res) == PGRES_TUPLES_OK)
{
printf("ok exec_select..\n");
} else {
cout << "res = "<< PQresultErrorMessage(res) << endl;
}
int oid;
oid = atoi(PQgetvalue(res,0, 0)); // записываю oid из результата запроса, используя который впоследствии достану блоб из системной таблицы
int lo_fd;
res = PQexec(conn, "begin");
PQclear(res);
lo_fd = lo_export(conn, oid, "../test/db2.db"); // экспорт блоба по oid-у из системной таблицы базы данных в файл
printf("lo_fd =  %d\n", lo_fd);
res = PQexec(conn, "end");
PQclear(res);

Подскажите пожалуйста, как можно обойтись без использования системной таблицы? В интернете и в книгах нашла информацию, с помощью которой файл записывается и выгружается только через таблицу pg_largeobject. Загрузить блоб напрямую в пользовательскую таблицу я еще предполагаю как.. например, можно попробовать:
Insert into table (oid, id, data) values (oid, id, lo_import('../test/database.db));
А как достать из пользовательской таблицы блоб, минуя системную, и записать его в файл?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
10.01.2019, 20:42
Ответы с готовыми решениями:

Как прочитать .ini файл без использования kernel32 на ubuntu?
Я написал программу, которая должна работать на ununtu. Но я не знал, что kernel32 - это библиотека исключительно Windows. А с помощью нее...

Из текстового файла прочитать четные числа и записать их в другой файл без использования массива (код С++)
Код есть только перед чтением файла нужно его создать, внести 15 чисел и закрыть, через ofstream. #include &lt;iostream&gt; #include...

Как прочитать файл без прав администратора?
Вот кусок кода: //Вне метода main ifstream ifs; //В методе main ifs.open(&quot;test.txt&quot;); if(!ifs.is_open()) { cout &lt;&lt;...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
10.01.2019, 20:42
Помогаю со студенческими работами здесь

Как открыть файл xls без использования OpenFileDialog?
Вечер добрый.Ниже приведен код который открывает файл xls и отображает содержимое в datagridview. Все бы ничего,но где прописать...

Как воспроизвести mp3 файл без использования дополнительных dll файлов?
Нужна помощь - как воспроизвести mp3 файл используя только NET Framework 4... и иметь возможность сделать повторы воспроизведения mp3 ...

Как прочитать xml файл из внешнего источника и на основе полученных данных сформировать HTML таблицы?
Дана задача, нужно по API получить листы с сервера, найти среди них с подтверждением(DoubleOptIn) и без(SingleOptIn). Вывести их отдельно...

Создание таблицы без использования стандартных элементов управления
Как мне создать динамически таблицу на форме, не используя DataGridView и GridControl, что бы название и тип столбцов брал из XML-файла? ...

Сделать из одной таблицы две, без использования макроса
Добрый день всем! Я новичек в Excel и меня интересует вот такое дело. Дана таблица(допустим N:N), из нее нужно сделать две, да так...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru