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

Парни, есть ответ JSON, который получаю по API. Как

мне сохранить (или обновить) его в БД максимально быстро? Сейчас я это делаю с помощью Foreach, но на 35 тыс записей тратится 26 минут. Можно как-то быстрее это делать?

10 ответов

14 просмотров

1. удалить то что есть 2. сформировать 1 большой массив 3. одной командой записать его в базу

либо пакетная вставки либо Prepared Statements

Ivan-Novikov Автор вопроса
Антон Шелестов
1. удалить то что есть 2. сформировать 1 большой м...

Я могу в этом случае использовать Item::updateOrCreate()?

Попробуй сначала собрать в коллекцию этот JSON (распарсить), и потом вставить.

Во-первых, в ларе есть insert для добавления множества записей за один раз. Это намного быстрее, чем использовать foreach. Однако функция insert не обновляет существующие записи. Если тебе нужно обновлять существующие записи, ты можешь использовать метод updateOrInsert, но он не предоставляет функцию массовой вставки или обновления. А вообще можешь посмотреть в торону использования какой нибудь либы Типа этой https://github.com/staudenmeir/laravel-upsert

Upsert попробуй.

Nirvana
вроде в новых версиях уже есть upsert

Да есть👍 https://laravel.com/docs/10.x/eloquent#upserts

Volodymyr Vi 🇺🇦
Да есть👍 https://laravel.com/docs/10.x/eloquent#u...

офигеть,уже 10 версия вышла . До сих пор сижу на 5,7 ((

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта