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

