Laravel - 删除所有关系

Laravel - Delete with all relations

我有一个系统,其中一个用户连接到很多不同的表,这些表也连接到不同的表。当我从我的数据库中删除一个用户时,与该用户关联的每个关系也应该被删除。我项目的关系设置如下所示

- A User user has multiple orders.
- An Order has multiple order items.
- Order Items belong to an order.
- A webshop belongs to a user and a webshop has One Main Setting.
- Main settings belongs to a webshop and has One address.
- Address belongs to main setting

当id为1的用户被删除时。 user_id 等于 1 的所有订单也应删除,没有问题。但是user_id为1的顺序也有Manyorder_items。例如,这个特定订单的 ID 为 3。所有 order_id 为 3 的 order_items 也应删除。这就是我 运行 进入这个问题的地方。

我的尝试

执行此操作会删除用户

$user = User::find($id);
$user->delete();

这样做会删除关系:

$user->orders()->delete();

但是如何删除与所有已删除订单关联的订单项目?我的尝试是:

$user->orders()->orderitems()->delete();

但不幸的是,这不起作用。 模型中的所有关系都工作得很好。所以所有可用的属性都是

User
- Orders();
- Webshops();
Order
- Orderitems();
Webshop
- Mainsetting();
Mainsetting
- Address();

我怎样才能完成上述任务?

如果您正在使用 MySQL(或任何支持级联的 RDBMS),您可以在数据库级别级联删除。如果不这样做,您必须在控制器上或通过模型事件监听函数手动处理它。 请参阅 documentation on migrations 详细说明外键约束。

Schema::create('order_items', function (Blueprint $table) {
    $table->increments('id');
    $table->unsignedInteger('order_id');
    $table->timestamps();

    $table->foreign('sell_order_id')
          ->references('id')
          ->on('orders')
          ->onDelete('cascade');
});

Note: Laravel supports soft deletes out of the box, as well as cascading soft deletes, see following article https://laravel-news.com/cascading-soft-deletes-eloquent

在迁移中使用外键并删除级联。

那么您只需删除订单,订单详情将自动删除。