172 похожих чатов

Может я в целом не совсем с той стороны решаю

проблему.
Задача такая. Мне нужно забирать снапшот из таблиц в pg, т.е. выгружать всё содержимое полностью и складывать в файл (например, csv) в S3. Таблица может быть 30-50 ГБ. Для меня база это сторонний сервис, так что я не могу изменить конфигурации или пользоваться консольными командами.
Мой подход - использовать copy-команду с STDOUT в файл. Если я верно понимаю, так данные едут потоком в открытый файл. В каждой таблице есть id и индекс по нему, так я могу итерироваться и выгружать записи частями. Но частями это костыль. Возможно есть другое ращение, как вытащить большую таблицу целиком в файл?

4 ответов

10 просмотров

А просто дамп таблицы делать не быстрее будет чем через питон?

Dmitriy-Matyukhin Автор вопроса

без возможности выполнять консольные команды? буду признателен, если тыкнете куда посмотреть, как это делать, ничего нормального я не нагуглил про это

Павел П.
А просто дамп таблицы делать не быстрее будет чем ...

Какбудто дамп как-то по-другому это делать будет.

Dmitriy Matyukhin
без возможности выполнять консольные команды? буду...

pg_dump запустить у себя, вообще не проблема. Только не поможэт, он всё тожэ самое делает.

Похожие вопросы

Обсуждают сегодня

Комрады, хотел уточнить. Проперть в OnDestroy юнита-хозяина по-прежнему доступна? И еще уточнение: finalization юнита наступает раньше или позже OnDestroy?
Ed Doc
38
Проблема с Windows scripting control Множество объектов получают iDispatch обертки и отдаются в скрипты. При этом скрипты могут эти обертки держать живыми очень долго, наприм...
Arioch The
16
Я тут пытаюсь переработать архитектуру подсистемы памяти ядра во что-то осмысленное. Есть pmm, который создает набор range’ей(пока что только для ядра, потом для юзерспейса), ...
Evg Resh
9
Скажите, можно ли как-то "переместить" динамический массив из одной переменной в другую? Скажем, переместить из TList<> в TArray<>. Именно переместить, а не скопировать. Если ...
Eugene Krasnikov (ᴊɪɴ x)
37
комрады, че-та лыжы не едут var tmpFont: TFont; begin tmpFont:= TFont.Create; try case rgFontColor.ItemIndex of 0: tmpFont.Color:= clWindowText; 1: tmpFo...
Ed Doc
34
Вот еще криповенькая штука. uMain.pas(517,3) Warning: Case statement does not handle all possible cases И ЧО? 😂
Александр (Rouse_) Багель
20
Интересно, нет ли какого-то способа получить из dll не адрес самой метки, а адрес со смещением?
The Bird of Hermes
54
коллеги, а есть простой способ определить, что программу из под Delphi запускают?
Михаил
10
40 тысяч в час / 3600 = 11,11 в секунду... Вам точно нужна очередь? (я просто не знаю "контекста") Такое количество запросов любое приложение замечательно "прожует" и не попер...
Igor Mitin
5
М-да. Почему бы просто со stringlist не работать?
Michael Longneck
23
Карта сайта