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

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

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

10 ответов

10 просмотров

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 ((

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

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

Мужики и девушки, привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных...
Kraszx
14
Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
Я вот подумал. SSE выполняет операции максимум с 64-битной точностью. А FPU - всегда с 80-битной. Разве не должно быть FPU точнее тогда?
The Bird of Hermes
13
как быть с принтером? такой подход прокатит?
zamtmn
12
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
Я не понимаю, это троллинг или что? Швабрика поддерживают, который буквально пишет на ассемблере взаимодействия с винапи. Я это ещё написал загрузчик и хоть что-то изучаю в о...
Shadow Akira
6
А вот это что за конструкция? Вернее, она тут нафига?
Serjone
10
Привет. Подскажите, как правильно сматчить лист фиксированного размера, чтобы компилятор не говорил мне о неполном паттерне? Допустим что-то такое [x', y'] = sort [x, y]?
Arseny
8
Карта сайта