Получение массового обновления для работы в laravel 5.6

Мое приложение создается на laravel 5.6

Ситуация: У меня есть таблица под названием «members» со столбцом под названием «membersstatus_id». варианты статуса: 4, 5 и 1
4 = активен, 5 = ожидает и 1 = срок действия истек

Цель: Я хочу обновить все активные (4) члена до ожидающих (5) и всех ожидающих истечения срока действия (1).

Решения, которые я пробовал: Пока что ниже показано то, что я пробовал безрезультатно.

    // get all active and pending members        
    $members = Member::where('membershipstatus_id', 5)
                ->orWhere('membershipstatus_id', 4)
                ->get();


    // bulk update with chunk of 200, if this is possible
    $members->chunk(200, function($members)
    {


        foreach($members as $member)
        {

            // if status is pending, update to expire
            if ($member->membershipstatus_id == 5)
            {
              $member->update(['membershipstatus_id' => 1]);
             }
            // if status is active, update to pending, i updated a small mistake here. 
            if ($member->membershipstatus_id == 5)
            {
              $member->update(['membershipstatus_id' => 4]);
             }


        }
    }
 );

return "update confirm";

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

Ашиш

Вы хотите просто иметь кнопку во внешнем интерфейсе, чтобы, когда вы нажимаете, происходят изменения, или вы хотите, чтобы возможность выбора пользователя, затем нажмите кнопку, и изменения произойдут?

mafortis 23.06.2018 05:33

Да @mafortis, вы совершенно правы.

ashish 23.06.2018 06:07

о каком? нужно выбрать вариант или просто кнопку?

mafortis 23.06.2018 06:10

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

Dharma Saputra 23.06.2018 06:10

должен быть if ($member->membershipstatus_id == 4) { $member->update(['membershipstatus_id' => 5]); }, я думаю

Dharma Saputra 23.06.2018 06:11

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

ashish 23.06.2018 06:16

@DharmaSaputra Да, я исправил это. Я допустил эту ошибку, когда набирал вопрос. Приложение имеет тот же код, что и вы предлагаете.

ashish 23.06.2018 06:20

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

ashish 23.06.2018 06:22
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
8
1 107
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Используйте конструктор запросов, например:

// update pending to expired
DB::table('members')
    ->where('membershipstatus_id', 5)
    ->update(['membershipstatus_id' => 1]);

// update active to pending
DB::table('members')
    ->where('membershipstatus_id', 4)
    ->update(['membershipstatus_id' => 5]);

возможно ли сделать что-то подобное ниже Member :: where ('membersstatus_id', 5) -> update (['membersstatus_id' => 1]);

ashish 23.06.2018 07:49

Спасибо, приятель, решено с использованием Member вместо DB

ashish 23.06.2018 09:14

Другие вопросы по теме