国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > PHP > 正文

Laravel 實現數據軟刪除功能

2024-05-05 00:10:59
字體:
來源:轉載
供稿:網友

對于任何一個模型,如果需要使用軟刪除功能,需要在模型中使用 Illuminate/Database/Eloquent/SoftDeletes 這個  trait 。軟刪除功能需要實現的功能有以下幾點:

1.模型執行刪除操作,只標記刪除,不執行真正的數據刪除

2.查詢的時候自動過濾已經標記為刪除的數據

3.可以設置是否查詢已刪除的數據,可以設置只查詢已刪除的數據

4.已刪除數據可以恢復

Model的軟刪除功能實現

Illuminate/Database/Eloquent/Model 中delete方法源碼:public function delete(){ if (is_null($this->getKeyName())) {  throw new Exception('No primary key defined on model.'); } if (! $this->exists) {  return; } if ($this->fireModelEvent('deleting') === false) {  return false; } $this->touchOwners(); $this->performDeleteOnModel(); $this->fireModelEvent('deleted', false); return true;}protected function performDeleteOnModel(){ $this->setKeysForSaveQuery($this->newModelQuery()) ->delete(); $this->exists = false;}

因為在子類中使用了 SoftDeletes trait,所以, SoftDeletes 的 performDeleteOnModel 方法會覆蓋父類的方法,最終通過  runSoftDelete 方法更新刪除標記。

protected function performDeleteOnModel(){ if ($this->forceDeleting) {  $this->exists = false;  return $this->newModelQuery()->where(    $this->getKeyName(), $this->getKey()  )->forceDelete(); } return $this->runSoftDelete();}protected function runSoftDelete(){ $query = $this->newModelQuery()      ->where($this->getKeyName(), $this->getKey()); $time = $this->freshTimestamp(); $columns = [$this->getDeletedAtColumn() => $this->fromDateTime($time)]; $this->{$this->getDeletedAtColumn()} = $time; if ($this->timestamps && ! is_null($this->getUpdatedAtColumn())) {  $this->{$this->getUpdatedAtColumn()} = $time;  $columns[$this->getUpdatedAtColumn()] = $this->fromDateTime($time); } $query->update($columns);}

Model查詢過濾刪除數據

Laravel中允許在Model中 static::addGlobalScope 方法添加全局的 Scope 。這樣就可以在查詢條件中添加一個全局條件。Laravel中軟刪除數據的過濾也是使用這種方式實現的。

SoftDeletes trait中加入了 Illuminate/Database/Eloquent/SoftDeletingScope 全局的 Scope 。并在 SoftDeletingScope 中實現查詢自動過濾被刪除數據,指定查詢已刪除數據功能。

public static function bootSoftDeletes(){ static::addGlobalScope(new SoftDeletingScope);}

遠程關聯數據的軟刪除處理

Scope的作用只在于當前模型,以及關聯模型操作上。如果是遠程關聯,則還需要額外的處理。Laravel遠程關聯關系通過 hasManyThrough 實現。里面有兩個地方涉及到軟刪除的查詢。

protected function performJoin(Builder $query = null){ $query = $query ?: $this->query; $farKey = $this->getQualifiedFarKeyName(); $query->join($this->throughParent->getTable(), $this->getQualifiedParentKeyName(), '=', $farKey); if ($this->throughParentSoftDeletes()) {  $query->whereNull(   $this->throughParent->getQualifiedDeletedAtColumn()  ); }}public function throughParentSoftDeletes(){ return in_array(SoftDeletes::class, class_uses_recursive(  get_class($this->throughParent) ));}public function getRelationExistenceQueryForSelfRelation(Builder $query, Builder $parentQuery, $columns = ['*']){ $query->from( $query->getModel()->getTable().' as '  .$hash = $this->getRelationCountHash() ); $query->join($this->throughParent->getTable(),   $this->getQualifiedParentKeyName(), '=', $hash.'.'.$this->secondLocalKey ); if ($this->throughParentSoftDeletes()) {  $query->whereNull($this->throughParent->getQualifiedDeletedAtColumn()); } $query->getModel()->setTable($hash); return $query->select($columns)->whereColumn(  $parentQuery->getQuery()->from.'.'.$query->getModel()->getKeyName(), '=', $this->getQualifiedFirstKeyName() );}

performJoin 中通過中間模型關聯遠程模型,會根據 throughParentSoftDeletes 判斷中間模型是否有軟刪除,如果有軟刪除會過濾掉中間模型被刪除的數據。

以上就是Laravel實現軟刪除的大概邏輯。這里有一個細節,Laravel中軟刪除的標記是一個時間格式的字段,默認 delete_at 。通過是否為null判斷數據是否刪除。

但是有的時候,項目中會使用一個整形的字段標記數據是否刪除。在這樣的場景下,需要對Laravel的軟刪除進行修改才能夠實現。

主要的方案是:

1.自定義 SoftDeletes trait,修改字段名稱,修改更新刪除標記操作;

2.自定義 SoftDeletingScope 修改查詢條件

3.自定義 HasRelationships trait,在自定義的 HasRelationships 中重寫 newHasManyThrough 方法,實例化自定義的 HasManyThrough 對象

總結

以上所述是小編給大家介紹的Laravel 實現數據軟刪除功能,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!


注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 长丰县| 城市| 岫岩| 长岭县| 儋州市| 大新县| 永和县| 隆昌县| 天津市| 凤冈县| 门源| 张家港市| 新密市| 滨州市| 丹阳市| 奉新县| 安吉县| 德阳市| 连江县| 德格县| 章丘市| 陇西县| 鄢陵县| 沙坪坝区| 衡南县| 长丰县| 古蔺县| 新龙县| 呼图壁县| 广宗县| 莱芜市| 柳江县| 铁岭市| 锡林郭勒盟| 铜陵市| 成都市| 天台县| 阳江市| 岗巴县| 云南省| 成武县|