请教个问题 中间表怎么做软删除?

请教个问题 中间表怎么做软删除?

hasaki
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
讨论数量: 3

不建议对pivot进行软删除, 有没有觉得这样做逻辑会很乱?

你可以在pivot上添加一个字段, 比如is_deleted, updateExistingPivot()可以修改这个字段, wherePivot('is_deleted', true)可以筛选数据.

\App\Book::find(1)->buyers()->wherePivot('is_deleted', true)->get()

\App\Book::find(1)->buyers()->updateExistingPivot(11, ['is_deleted' => false])

或者在关系里面定义俩关系

function buyers() {
    return $this->belongToMany('App\User')->wherePivot('is_deleted', false);
} 

function buyersWithDeleted() {
    return $this->belongToMany('App\User');
}
7年前 评论

@copydog

我希望的是

$xxx->detach('xxxx')

的时候不真正的删除里面的数据就可以了- -
谢谢你的回答

7年前 评论

@我是谁

可以考虑以下方法.

方法1:

用sync代替detach.

方法2:

修改关系类

首先继承和修改下BelongToMany类, detach函数在InteractsWithPivotTable这个trait里面可以找到.

接着在你需要的修改detach功能Model里面重写belongToMany()方法, 如果是L5.4可以再HasRelationships这个trait里面可以看到原始实现, L5.3直接在Model.php里面可以看到

方法3:

在原始代码中修改detach函数

7年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!