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

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

записей.
<?php

namespace App\Http\Controllers;

use App\Models\Post;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;

class PostsController extends Controller
{
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
public function index()
{
$post = Post::updateOrCreate([
'title' => 'Post 3'
], [
'description' => 'Description for post 3.',
'body' => 'body for post 3 - updated.'
]);

print_r($post);die;
}
}
Поэтому рассматриваю updateOrCreate()
В документации предлагается:
try{
DB::beginTransaction();

/*
* Your DB code
* */

DB::commit();
}catch(\Exception $e){
DB::rollback();
}
Вопрос такой, пропустить весь запрос через foreach
Post::updateOrCreate([
'title' => 'Post 3'
], [
'description' => 'Description for post 3.',
'body' => 'body for post 3 - updated.'
]);
Или в updateOrCreate() вторым параметром передать многомерный массив. Пример кода не мой, скопировала, title условно будет разный.
Так что скорее всего понадобится foreach или рекурсивная функция, пока не переберу весь массив. Основной момент за который я переживаю, это нагрузка на базу данных. Цель: сделать оптимизированный мультизапрос
updateOrCreate()

5 ответов

3 просмотра

iQs Solution, мы обнаружили что Ваше сообщение больше чем наполовину состоит из кода. Рекомендуем сохранять примеры кода на внешних источниках, например, https://paste.laravel.io

Если тебе массовое обновление - то метод upsert если создание, то create поддерживает массовое создание Транзы в таком случае тут не нужны

DB::transaction(function () { // code }) Упростит работу с транзакциями.

iQs-Solution Автор вопроса
Игорек
Если тебе массовое обновление - то метод upsert ес...

Нет, у меня там проверка на создание или обновление, если запись есть поэтому использую это свойство, чтобы не делать лишних проверок-запросов. Вот почему updateOrCreate() а не upsert или create. Там и обновление и запись.

iQs-Solution Автор вопроса
Andrey Helldar
DB::transaction(function () { // code }) Упрост...

Я привела пример в своём вопросе, это я знаю, где // code хочу сделать оптимальный запрос. Просто знаю что в случае с insert into я могу в VALUE передать целый массив данных, а не одну строчку на запись, но у меня ещё проверка на is exist

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

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

а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Добрый день. Хочу сделать отрисовку по команде на панели. Почему-то рисуется только при втором вызове. С чем может быть связано, не подскажете? procedure TForm1.FormDblClick(...
Kirill Filippenok
20
Всем доброго дня! Подскажите может кто использовал связку Pagebuilder + Clientsetting. Сами параметры с типом pagebuilder в модуле Clientsetting работают нормально, можно такж...
Александр Добриков
12
А почему в си некоторые вещи работают с двойными кавычками некоторые с одинарными? Нельзя было все сделать с одними или чтоб работало с разными? например чтоб выводить строки ...
.
15
Всем привет! Нужен совет от опытных. Переношу свой проект с Делфи 10.2 Токио на Лазарус 3.2 установленный через инсталлятор fpcupdeluxe-x86_64-win64. При импортировании проект...
Дмитрий Завгородний
7
Эх кто-то пришел и весь праздник испортил :( You need complex FBX scene importing setup to change things on import? good luck with that. You need navigation and pathfinding? g...
Serg Gini
5
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Всем привет! procedure TForm1.FormCreate(Sender: TObject); type TStartEnd = record S: Byte; E: Byte; end; var a, b: TStartEnd; begin {1} a.S := 1; {2} a.E := 2; ...
Руслан Михайлович
10
Всем привет!) я тут новенький и пытаюсь освоить evolution методом тыка. У меня при переходе между папками файлов выскакивают вот такие уведомления Можете подсказать как их от...
Диман Samoed
10
Какого хера? /Sources/App/Modules/User/Models/UserLinkApple.swift:21:20: warning: stored property '_id' of 'Sendable'-conforming class 'UserLinkApple' is mutable @ID(...
Alexander Sherbakov
14
Карта сайта