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 ответов

17 просмотров

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

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

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

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
Ребят в СИ можно реализовать ООП?
Николай
33
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
у вас два процесса. один посылает другому сигнал. у вас есть код обоих процессов? если всё не так - расскажите как оно на самом деле. а именно кто кому чего, есть-ли консоли,...
Karagy
6
Карта сайта