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

Всем привет. Необходимо вставить, или обновить записи в таблице базы Делал

так, типа ищу user_id, если его нет то создаю
если он есть то обновляю.

$response = \DB::table('Contacts')->updateOrInsert(
[
'user_id' => $Params['user_id'] // ищем user_id = XXX
],
[
'name' => $Params['name'] // создаем/обновляем имя
]
);


Все гуд и так все работает.
тока вопрос, если мне необходимо выполнить такое же для 300 к примеру контактов?

в цикле выполнять запрос к базе - не есть хорошо, как же так бы пакетно все это сделать?

16 ответов

5 просмотров

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

Отличный совет

Роман-Webds Автор вопроса

)) нее я лучше убью время

То, что ты ищешь, гуглится по слову "laravel bulk update", больше ничего не скину, т.к. с телефона)

Роман-Webds Автор вопроса

laravel bulk update ща посмотрю

Роман-Webds Автор вопроса

нашел, в 8-й ларке появился upsert , как бы его на 7-й ларке выполнить

Скопипастить код

чего появилось?

Роман-Webds Автор вопроса

в ларьке 8 нашел то что мне нужно. появился метод там upsert (https://www.amitmerchant.com/insert-or-update-multiple-records-using-upsert-in-laravel8/) тока не совсем понял, это пакет отдельно используется или вшит метод в ларку. Кто его использовал уже? И самый вопрос - как бы мне его использовать в Ларке 7-й

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

Роман-Webds Автор вопроса

правильно ли я понял: 1. находим как реализован метод upsert в ларьке 8 2. создаем макрос - куда дописываем необходимый функционал, который в ларьке 8 3. подключаем макрос к ларьке 7 через композер, если много макросов то через класс Миксин

3. в сервис провайдере подключаешь его

Роман-Webds Автор вопроса

ну или так или через композер- я прочитал можно так и так. Сейчас теперь вопрос как бы вытащить полную функциональность по методу upsert

вот что я нагуглил https://gist.github.com/tomcastleman/7285a59ee242f929e0cbe6974bc4b799

гист старый, сравни такой ли синтаксис upsert в новой версии

Роман-Webds Автор вопроса

ага, я понял, сравню сейчас, это уже ктото делал макро я так понимаю

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

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

А чем вам питонисты не угодили?😂
.
79
Dim Dim, [02.07.2024 11:07] DB 0x62 Dim Dim, [02.07.2024 11:07] DB 0x66 Dim Dim, [02.07.2024 11:07] кто пояснит что это?
Dim Dim
14
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
11
Кстати, я тут еще с одной темой столкнулся, вот учу я C++, на таком то ресурсе, а остальные постоянно советуют практиковаться, что то писать, проекты, но как писать если вот т...
aaswq1
7
Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
Ребят, кто сталкивался с тем, что Electron.js не разворачивает билд React.js-приложения? Голый body в чёрном цвете, как и должно быть, но остального - нет. Билд работает исп...
..
6
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Anyone knows how to build this widget in Flutter? I have all the assets for round stations and the road, but how can I make the my widget animate between these stations? And h...
Mohammad Zamani
9
А как лучше конвертировать физический адрес в виртуальный при маппинге? В случае ядра у меня, например, direct mapping, первые 768МБ я как есть мапплю в higher half, а остальн...
Evg Resh
26
Карта сайта