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

20 просмотров

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

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта