решил написать импорт в бд из excel. В итоге получились коллбэки вложенные друг в друга. Возникла проблема: объекты в бд добавляются все одновременно, а не по очереди. БД состоит из Этажа, комнаты и людей. При импорте я беру одну запись, сначала проверяю есть ли такой этаж, если нужно - создаю. Потом с комнатой. А потом создаю человека и добавляю ему ссылки на комнату. Обычно ,в одной комнате 4 человека, и постонно получается, что комната создается 4 раза. Почитал в интернете, пишут, что можно последовательно добавлять используя промисы. Но пока у меня получились вложенный коллбэки и чет догнать не могу, как их развернуть аккуратно, может кто-то пример может привести в контексте mongoose, как цепочку промисов сделать правильно? Код тут https://pastebin.com/Z6ivM4J8
я бы обвернул в промисы и запустил все это дело через Promise.All
1) код запущенный в forEach будет выполнен после того как сервер вернет результат, поэтому ваш код возвращал 501 ошибку. Я использовал for/Bluebird. 2) Promise'ы должны образовывать цепочку. То есть паттерн такой: Promise.then(result=>{ return Promise }).then(result{ return Promise }) Стоит обратить внимание на более современный подход async/await. then/catch может быть так же полезен в некоторых ситуациях. 3) Так же не нужно использовать Promise.all в этом случае, т.к. это скорее всего создаст нагрузку на БД. Если скорость важна, то можно использовать Bluebird и указать опцию concurrency. 4) Вместо formidable я бы рекомендовал multer. 5) Express не умеет в async/await, так что ошибки будут игнорироваться а клиент не получит ответ. Поэтому вам нужно оборачивать все подобные роутеры в withAsync. Я не тестировал код. Использовать это нужно так: router.post('/api/upload', isAdmin, upload.single('file'), importPeoples) https://pastebin.com/03ANgFyc
Обсуждают сегодня