1. 程式人生 > 程式設計 >django orm模組中的 is_delete用法

django orm模組中的 is_delete用法

資料庫刪除資料咱都知道,簡單的說就是當一條資料對企業沒用後,一般人可能會選擇刪除這條資料。

但是刪除後,萬一以後又突然有用呢。所以我們這時候會選擇在寫orm模組的時候,加入is_delete欄位

is_delete = models.BooleanField(default=False,verbose_name='是否刪除')

這樣以後咱如果要刪除一條資料了,就設定一下

is_delete=1

就表示這條資料在邏輯上刪除了,簡單的說就是你再怎麼搜資料庫也搜不到了,如果以後還用,就再設定

is_delete=0

就可以了!

補充知識:django中當model設定了ordering後,使用distinct()和annotate()問題記錄

model類如下,我在class Meta中設定了ordering = ['-date_create'],即模型物件返回的記錄結果集是按照這個欄位排序的。

class SystemUserPushHistory(models.Model):
 
  id = models.UUIDField(default=uuid.uuid4,primary_key=True)
  host_name = models.CharField(max_length=128,null=False)
  system_username = models.CharField(max_length=128,null=False)
  method = models.CharField(max_length=32,null=False)
  is_success = models.BooleanField(default=False)
  date_create = models.DateTimeField(auto_now_add=True,editable=False)
  message = models.CharField(max_length=4096,null=True)
 
  class Meta:
    db_table = "assets_systemuser_push_history"
    ordering = ['-date_create']
 
  def __str__(self):
    ret = self.system_username + " => " + self.host_name
    return ret

當業務有需求如對host_name進行分組顯示,在程式碼中用到了annotate,如下。

>>> from django.db.models import Count 
>>> from assets.models import SystemUserPushHistory
>>> p = SystemUserPushHistory.objects.values("host_name").annotate(dcount=Count(1))
>>> p
<QuerySet [{'host_name': '點2','dcount': 1},{'host_name': '點3','dcount': 2},{'host_name': '點2','dcount': 1}]>
>>> print(p.query)
SELECT `assets_systemuser_push_history`.`host_name`,COUNT(1) AS `dcount` FROM `assets_systemuser_push_history` GROUP BY `assets_systemuser_push_history`.`host_name`,`assets_systemuser_push_history`.`date_create` ORDER BY `assets_systemuser_push_history`.`date_create` DESC

可以看到,所得到的結果並不像我們預期的一樣,之後把執行的sql輸出出來可以看到在group by的時候是對host_name和date_create進行分組,原因就是因為我們在model類中設定了ordering,去掉之後程式碼執行正常。

使用distinct和上面的情況類似,就不列出來了。

以上這篇django orm模組中的 is_delete用法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。