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

Привет. Имеется массив массивов вида $arr = [ ['id'=>1,'age'=>12] ,

['id'=>1,'age'=>32] ....n ]

Есть ли возможность средствами ORM ларки обновить пачку данных в таблице ?

Хотел использовать метод upsert , но ругается на то, что мол не все поля с данными присылаю, а только часть.

18 ответов

33 просмотра

заверни в транзакцию и в цикле запусти обновление по-строчно, что ты хочешь выиграть отправив это все одним запросом, на стороне базы данных в итоге будет тот же цикл с теме же проверками на существование, а может быть и того хуже попытки вставки получение ошибки и т.д.

Egor Gruzdev
заверни в транзакцию и в цикле запусти обновление ...

upsert делает INSERT INTO table (...) VALUES (...), (...), (...) ON DUPLICATE KEY UPDATE (...) и это гораздо лучше циклов и т.п.. пусть даже и в транзакции

Egor Gruzdev
о каких объемах идет речь?

а что объемы вещь постоянная ? сегодня у него 10 строк .. а завтра в сотни раз больше

Иван-Марков Автор вопроса
Egor Gruzdev
о каких объемах идет речь?

100 строк примерно за раз (но часто)

Иван Марков
100 строк примерно за раз (но часто)

часто это как 60 раз в секунду или 1 раз в сутки

ну так проблема в том что при интсерте в таблицу не хватает данных , так как недостающие поля не имеют дефолтных настроек ... Вы либо передавайте их либо в таблице пропишите

Иван-Марков Автор вопроса
Egor Gruzdev
часто это как 60 раз в секунду или 1 раз в сутки

тут все зависит от нагрузки, пока не могу точно сказать, но надо много и часто в минуту будет обновлять таблицу.

Иван-Марков Автор вопроса
Vitaly Larin
ну так проблема в том что при интсерте в таблицу н...

а, т.е. как вариант я же могу от балды указать значение недостающих полей, а обновить в итоге только нужное, так как я заведомо знаю что они есть

Vitaly Larin
upsert делает INSERT INTO table (...) VALUES (...)...

мое мнение, что upsert больше минусов, чем плюсов

Иван-Марков Автор вопроса

да. это просто костыль для метода upsert получится

Иван Марков
да. это просто костыль для метода upsert получится

измените таблицу и костыль не понадобиться

Иван-Марков Автор вопроса
Иван Марков
ну или запрос )

Вы превратите 1 простое действие в цепочку последовательных действий

- если хоть с одной записью проблема, вся работа по бороде (в случае цикла можно пропустить и повторить работы с ошибочными записями) - улетающий в бесконечность целочисленный autoincrement - отлов где произошла ошибка, также сложно, т.е. что из 1000 строк sql вызвало проблему это то что по опыту вспомнилось а по скорости, в частности 90% когда база данных на том же сервере где и приложение особо выигрыша я не замечал а вот удобство поддержки построчной вставки/обновления, понимание что происходит, возможность задать значения по умолчанию в приложении, а не надеяться на базу данных, значительно превосходит выигрыш в доли секунд

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

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

@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
Подобного рода ;Следующие три строки это директивы ассемблера, ;которые можно не задавать, т.к.работаем в Visual Studio. ;Символ ";" - это начало однострочного комментария ...
Егор Анелькин
3
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
открыть папку в проводнике: 1 - ShellExecute 2 - ExecuteProcess 3 - OpenDocument что лучше выбрать?
Alexey Kulakov
12
еще вопрос, допустим мы создадим char массив из 10 элементов и присвоим ему через сканф 10 символов. и выведем все символы. Хотел спросить последний элемент /0 будет включать...
Anthem
10
Подскажите, где смотреть результат выполнения программы? Код: ;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, станда...
Егор Анелькин
5
Где в Астане можно купить мясо для шашлыков?
Dancing Іңұқәһүғө
21
;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, стандартный ;вызов процедуры ;option casemap:no...
Егор Анелькин
1
Карта сайта