Подтвердить что ты не робот

Laravel 5: каскадное мягкое удаление

У меня есть таблица предлагает и службы.

Сервис - ребенок предложения. До сих пор я создал функциональность для мягкого удаления предложения. Как я могу также мягко удалить добавленные службы? Вот мой код:

Предложения миграции

Schema::create('offers', function(Blueprint $table)
{
    $table->increments('id')->unsigned();
    ...    
    $table->timestamps();
    $table->softDeletes();
});

Услуги миграции

Schema::create('services', function(Blueprint $table) 
{
    $table->increments('id');
    $table->integer('offer_id')->unsigned();   
    ...
    $table->timestamps();
    $table->softDeletes();
});

Schema::table('services', function($table) 
{
    $table->foreign('offer_id')
          ->references('id')
          ->on('offers');
});

Предложение модели

use SoftDeletes;
protected $dates = ['deleted_at'];

public function services() {
    return $this->hasMany('App\Service');
} 

Сервис модели

public function offer() {
    return $this->belongsTo('App\Offer');
} 

Метод удаления

public function destroy($id)
{
    $offer = Offer::find($id);
    $offer->delete();
}

Спасибо за помощь.

4b9b3361

Ответ 1

Я поместил этот код в модель предложения:

protected static function boot() {
    parent::boot();

    static::deleting(function($offer) {
        $offer->services()->delete();
    });
}

И добавил отсутствующий

use SoftDeletes;
protected $dates = ['deleted_at'];

в модели Service.

Ответ 2

Для этого вам следует использовать Красноречивые события.

Offers::deleted(function($offer) {
    $offer->services()->delete();
});

Offers::restored(function($offer) {
    $offer->services()->withTrashed()->restore();
});

Ответ 3

Вы можете сделать это.

self::deleting(function($offer) {
    $offer->services()->delete();
});

self::restoring(function ($offer) {
   $offer->services()->restore();
});

Прежде чем удалять/восстанавливать родителя (предложение), вы должны сначала удалить/восстановить записи (службы). В противном случае будет вызвана ошибка ссылочной целостности MySql.

Ответ 4

Если вы хотите получить каскадные softDeletes в своих Eloquent Models, я настоятельно рекомендую использовать эту библиотеку iatstuti/laravel-cascade-soft-deletes

Composer

// get it with composer.
$ composer require iatstuti/laravel-cascade-soft-deletes="1.0.*"

Быстрый пример (тот, который указан в примере с запуском)

<?php

namespace App;

use App\Comment;
use Iatstuti\Database\Support\CascadeSoftDeletes;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\SoftDeletes;

class Post extends Model
{
    use SoftDeletes, CascadeSoftDeletes;

    protected $cascadeDeletes = ['comments'];

    protected $dates = ['deleted_at'];

    public function comments()
    {
        return $this->hasMany(Comment::class);
    }
}