Django中軟刪除的具體實現(xiàn)
軟刪除(Soft Delete)是一種數(shù)據(jù)刪除策略,它并不真正從數(shù)據(jù)庫中刪除記錄,而是通過標(biāo)記(如 is_deleted 字段)來表示記錄已被刪除。
這樣做的好處是可以保留數(shù)據(jù)歷史,支持?jǐn)?shù)據(jù)恢復(fù)和審計。
在 Django 里可以通過 自定義 Manager + 重寫 delete 方法 來實現(xiàn)。
1. 在模型里增加is_delete字段
from django.db import models
class BaseModel(models.Model):
is_delete = models.BooleanField(default=False, verbose_name="是否刪除")
class Meta:
abstract = True # 抽象基類,不會建表
這樣所有繼承 BaseModel 的表都有 is_delete 字段。
2. 自定義 Manager(默認(rèn)過濾掉刪除的記錄)
class ActiveManager(models.Manager):
def get_queryset(self):
# 默認(rèn)只返回 is_delete=False 的數(shù)據(jù)
return super().get_queryset().filter(is_delete=False)
3. 在模型里應(yīng)用 Manager
class User(BaseModel):
name = models.CharField(max_length=100)
# managers
objects = ActiveManager() # 默認(rèn)只取未刪除的
all_objects = models.Manager() # 需要時可以取所有(包括已刪除的)
這樣:
User.objects.all() # 只會查 is_delete=False User.all_objects.all() # 不加過濾,所有數(shù)據(jù)都能查
4. 重寫delete()方法(軟刪除)
class User(BaseModel):
name = models.CharField(max_length=100)
objects = ActiveManager()
all_objects = models.Manager()
def delete(self, using=None, keep_parents=False):
self.is_delete = True
self.save(update_fields=['is_delete']) # 只更新 is_delete 字段
這樣:
u = User.objects.get(id=1) u.delete() # 不會真正刪除,只會把 is_delete 置為 True
5. 如果要做批量刪除
Django 的 QuerySet.delete() 默認(rèn)會直接刪掉數(shù)據(jù),所以我們也可以自定義一個 QuerySet 來支持批量軟刪除:
class SoftDeleteQuerySet(models.QuerySet):
def delete(self):
return super().update(is_delete=True)
結(jié)合 Manager 使用:
class ActiveManager(models.Manager):
def get_queryset(self):
return SoftDeleteQuerySet(self.model, using=self._db).filter(is_delete=False)
這樣就支持:
User.objects.filter(name="Tom").delete() # 也會變成軟刪除
? 總結(jié):
is_delete字段標(biāo)記是否刪除。- 自定義 Manager 過濾掉已刪除的數(shù)據(jù)。
- 重寫
delete()實現(xiàn)軟刪除邏輯。 - 如有需要,配合自定義
QuerySet處理批量軟刪除。
到此這篇關(guān)于Django中軟刪除的具體實現(xiàn)的文章就介紹到這了,更多相關(guān)Django 軟刪除內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于Python3 lambda函數(shù)的深入淺出
今天小編就為大家分享一篇關(guān)于Python3 lambda函數(shù)的深入淺出,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11
Django中數(shù)據(jù)庫遷移常用的命令小結(jié)
在Django中數(shù)據(jù)庫遷移用于保持?jǐn)?shù)據(jù)庫結(jié)構(gòu)與模型定義同步,這篇文章主要介紹了Django中數(shù)據(jù)庫遷移常用的命令,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2025-03-03
Python ORM框架SQLAlchemy學(xué)習(xí)筆記之安裝和簡單查詢實例
這篇文章主要介紹了Python ORM框架SQLAlchemy學(xué)習(xí)筆記之安裝和簡單查詢實例,簡明入門教程,需要的朋友可以參考下2014-06-06
PyTorch數(shù)據(jù)讀取的實現(xiàn)示例
這篇文章主要介紹了PyTorch數(shù)據(jù)讀取的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
Django websocket原理及功能實現(xiàn)代碼
這篇文章主要介紹了Django websocket原理及功能實現(xiàn)代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-11-11

