Размер памяти исчерпан действием мягкого удаления laravel

В Laravel 5.6, когда я пытаюсь мягко удалить все данные в таблице с большими записями с моей функцией:

public function clearActivityLog() {
    $activities = Activity::all();

    foreach ($activities as $activity) {
        $activity->delete();
    }

    return redirect('admin/activity')
        ->with('success', trans('backend/main.logs.activity.messages.logClearedSuccessfuly'));
}

Я получаю такую ​​ошибку:

Allowed memory size of 134217728 bytes exhausted (tried to allocate 20480 bytes)

Стоит ли изучать 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
0
656
3
Перейти к ответу Данный вопрос помечен как решенный

Ответы 3

Если есть много действий, это потенциально может вызвать огромное количество запросов. Это можно сделать с помощью одного запроса:

Activity::query()->update('deleted_at', now());

softdeletes использует столбец deleted_at, чтобы проверить, удалена ли строка. Таким образом, установка столбца вручную для всех строк дает тот же эффект.

хороший ответ, но нестатический метод update () не должен вызываться статически

user7262001 12.10.2018 15:33

Исправлено, если сначала поставить query().

Jerodev 12.10.2018 15:36
Ответ принят как подходящий

В этом случае ответ Джеродева хорош.

В некоторых случаях вы не можете выполнить массовое обновление (например, если вам нужно выполнить обработку для каждого элемента или если вам нужно запускать события Eloquent). В этих случаях вы можете избежать нехватки памяти, используя chunk:

Activity::chunk(100, function($activities) {
    foreach ($activities as $activity) {
        $activity->delete();
    }
});

При этом в память загружается только 100 (вы можете выбрать любое число здесь) за раз (по сравнению с Activity::all(), который загружает каждое действие в память сразу; если это миллионы строк, вы можете легко понять, почему вы получите ошибку памяти).

Мне это нравится, потому что если по какой-либо причине мягкое удаление в конечном итоге превратится в жесткое удаление, это продолжит работать.

user1669496 12.10.2018 15:28

То же самое и с Activity::query()->delete();, и для него требуется один запрос к базе данных вместо одного для каждого действия в базе данных.

wheelmaker 12.10.2018 15:36

Более "красноречивое" решение (и, вероятно, более перспективное для будущего)

Activity::query()->delete();

Это извлекает построитель запросов для модели Activity без ограничений, поэтому delete () будет применяться ко всем. Он не загружает все действия, а вместо этого удаляет их за один вызов. Он также показывает отсутствие знаний о внутренней работе мягких удалений, что предпочтительно для прямой совместимости.

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

user7262001 12.10.2018 15:35

Пожалуйста, дважды проверьте, что это правда, и если да, сообщите об ошибке команде Laravel на github.

wheelmaker 12.10.2018 15:38

ты тоже правильно работаешь, но я не знаю, почему у меня возникла такая проблема !! в любом случае спасибо всем.

user7262001 12.10.2018 15:46

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