Laravel - 删除所有关系

标签 laravel laravel-5 laravel-4 relationship

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

- 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的订单也有很多order_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),您可以在数据库级别级联删除。如果没有,您必须在 Controller 上手动处理它或通过模型事件监听功能。 请参阅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

关于Laravel - 删除所有关系,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50503464/

相关文章:

php - Twitch API redirect_mismatch

php - 使用 Paypal php rest SDK 汇款

php - 无法在 PHP 中将字符串转换为 float - Laravel 5.2

php - Laravel:获取复选框的值

php - 数据库中的复杂关系(使用 Laravel)

Laravel 在生产服务器中的存储路径

php - 为什么我在 Laravel 中删除用户帐户时没有注销

php - 碳日期的格式时区

php - 如何使用auth中间件来管理不同用户类型的登录/重定向?

php - Laravel 4 文件上传