mysql запрос использует ON DUPLICATE KEY UPDATE нужно его в pg переделать
Разработка сервиса выгрузки отчётов, Node.js + Koa на бэке, Vue.js на
[table]ЗадачаСуществует система проведения олимпиад. Изнутри это, на самом деле, достаточно сложная вещь с богатой функциональностью (говоря умными словами, она поддерживает ведение проектной деятельности по информационному, техническому и методическому обеспечению олимпиад). Естественно, под всю эту функциональность имеются сущности в БД, и иногда по этим сущностям нужно проводить аналитику (обычно это относится к разным спискам участников). В данный момент система позволяет фильтровать данные по заданным критериям, сортировать их и выгружать в XLSX для дальнейшей ручной обработки. Если брать списки участников, то там можно выгружать результаты по различным турам, потокам площадок, на которых пользователь писал или будет писать заключительный этап, вхождение в различные системные группы, их школы/города/регионыЧто тут нас не устраивает:
Операции выгрузки иногда занимают много времени, особенно если они большие. Выгрузка происходит не в фоне, т.е. пользователь нажимает на кнопку выгрузки и ждёт, пока она выгрузится. Причём не факт, что табличка в итоге попадёт к пользователю, поскольку трафик идёт через NGINX, который обрывает соединения, от которых нет ответа определённое время. В таком случае пользователь просто получит ошибку 504
Как это должно выглядеть в итоге: пользователь нажимает на кнопку выгрузки, и система ему отвечает, что выгрузка начинает создаваться где-то в фоне и можно работать с другими страницами. В это время система где-то в фоне генерирует выгрузку, сохраняет результирующий файл и прочую информацию (когда и кем выгружено, что выгружалось, с какими параметрами и т.д.) в отдельную табличку. После сохранения система уведомляет пользователя, что выгрузка готова и что её можно скачать на определённой странице интерфейса
Как это предлагается реализовывать: у нас уже есть набор фоновых процессов, которые слушают запросы от основного приложения через Redis. Можно сделать ещё один такой процесс, который будет вызывать существующую функцию выгрузки. В этом процессе будет происходить сама выгрузка, не влияя на основное приложение (т.е. NGINX рвать соединение не будет, т.к. его просто нет). После сохранения самой выгрузки и её мета-информации процесс должен как-то сообщить пользователю, что выгрузка готова. Это можно сделать, наверно, через веб-сокеты. Также тебе нужно будет отрефакторить метод для создания выгрузки, т.к. её разработчик (изначальный разработчик системы) раздул его на 100+ строк, это неудобно читать и наверняка там остались баги[/table]
Заявки фрилансеров
Похожие заказы
- Базы данныхнет заявокЗакрыт4 года назад
Есть числа в базе данных. Нужно рассчитать максимальную серию не выпадения. Пример Числа: 0 0 0 0 1 2 1 1 2 3 4 5 5 6 5 ...
Базы данныхнет заявокЗакрыт4 года назадК существующей базе данных MS SQL Server (или Oracle), состоящей из 2х таблиц (Movies - 6 полей и Orders - 6 полей), написать веб-приложение на Java (или на C#), поволяющее: ...
Базы данных1 заявкаЗакрыт4 года назадСеть стриптиз-клубов ищет на постоянную работу PHP программиста (удаленно) ЗП 1200 -1400 USD (точно определим по результатам собеседования) Технические требования: - PHP, в том числе хорошие ...
Базы данных15 заявокЗакрыт4 года назадЕсть старенькая программка softlogic plc под Windows XP управления установкой по производству бетона. Delphi+Firebird. Исходников нет. Желания модернизироваться у заказчика нет. Весь процесс выпуска бетона фиксируется в БД. Нужен отчет, предположительно IBExpert/Report Manager,для вывода печатной ...
Базы данных1 исполнительЗавершен4 года назад- $5
Нужны урл всех разделов из каталога Авито. Результат нужен в ексель с разбивкой по столбцам/строкам для удобства выборки урл из требуемых категорий/разделов.
Базы данных1 заявкаЗакрыт4 года назад Добрый день! Требуется написать ТЗ для базы данных (точнее, для дополнительных модулей в имеющейся БД). Сроки кратчайшие
Базы данных1 заявкаЗакрыт4 года назадНужно разработать парсер Facebook с возможностью выгрузки результатов в excel-файл. Разработка "под ключ" (прокси/впс/обход капчи...). Какие данные ожидаются в результате парсингаFB : Друзья/подписчики юзера - ФИО, ссылка на профиль, email, дата ...
Базы данныхнет заявокЗакрыт4 года назадПереход с Magento 1 на Magento 2, настройка, перенос всех модулей (установка новых модулей), в частности "M2E". Доработка действующего сайта на базе Magento 1. Необходимо ускорить загрузку сайта. Проверить работоспособность сайта и устранить ...
Базы данныхнет заявокЗакрыт4 года назадНужно спарсить порядка 2500 карточек товаров - данные и фотографии с сайта, адрес в приложении. Там гораздо больше товаров, мне нужны только те которые фильтруются определенными фильтрами, при обсуждении проекта расскажу подробнее. Потом ...
Базы данных3 заявкиЗакрыт4 года назад