Есть ли способ программно вызвать MySQL LOAD DATA INFILE из NODE.js, передавая поток?

Есть ли способ передать поток из процесса node.js в MYSQL LOAD DATA INFILE?

В Postgres это можно сделать ...

const dumpFile = fs.createReadStream(dumpFilePath);
const copyStatement = `copy "STAGING_TABLE" from STDIN`;
const stream = pgClient.query(copyFrom(copyStatement));
stream.on('end',function() {console.info('done'})
stream.on('error',function(err){console.info('Error')});
dumpFile.pipe(stream);

MySQL LOAD DATA INFILE, по-видимому, предлагает в целом аналогичные функции для копирования из файла, но, похоже, не имеет возможности использовать stdin вместо фактического файла в локальной файловой системе. Также драйвер node.js для MYSQL, похоже, не имеет эквивалента модуля pg-copy-stream, который позволяет копировать поток на сервер.

Я предполагаю, что вы имеете в виду LOAD DATA INFILE LOCAL, и я не вижу никого, у кого есть запросил эту функцию. Возможно, стоит запросить. Я бы попросил, чтобы он был реализован как обратный вызов, а не привязывал его к реализации потока.

danblack 18.09.2018 01:59

@danblack. Новичок в MySQL, поэтому я открыт для предложений. Параметр local может удовлетворить мои потребности, если я могу использовать его из NODE.js, поскольку в этом случае я просто буду создавать поток чтения в файле .. Однако если мне нужно выполнить предварительную обработку файла перед его отправкой Я думаю, что база данных, основанная на потоковой передаче или обратном вызове, все равно будет полезна ...

mark d drake 18.09.2018 02:07

Использование его без общей функции для нефайлового использования будет немного беспорядочным. Лучшая альтернатива, которую я предлагаю, - это преобразовать данные в node.js в правильные операторы INSERT.

danblack 18.09.2018 02:11

К сожалению, файл представляет собой просто один большой блок JSON, который я хочу сохранить как таковой ...

mark d drake 18.09.2018 02:16
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
В последние годы архитектура микросервисов приобрела популярность как способ построения масштабируемых и гибких приложений. Laravel , популярный PHP...
Как построить CRUD-приложение в Laravel
Как построить CRUD-приложение в Laravel
Laravel - это популярный PHP-фреймворк, который позволяет быстро и легко создавать веб-приложения. Одной из наиболее распространенных задач в...
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
В предыдущем посте мы создали функциональность вставки и чтения для нашей динамической СУБД. В этом посте мы собираемся реализовать функции обновления...
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
Роли и разрешения пользователей без пакета Laravel 9
Роли и разрешения пользователей без пакета Laravel 9
Этот пост изначально был опубликован на techsolutionstuff.com .
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
0
4
106
0

Другие вопросы по теме