歡迎您光臨本站 註冊首頁

django orm模塊中的 is

←手機掃碼閱讀     f2h0b53ohn @ 2020-06-10 , reply:0

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

但是刪除後,萬一以後又突然有用呢。所以我們這時候會選擇在寫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>>> 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和上面的情況類似,就不列出來了。


[f2h0b53ohn ] django orm模塊中的 is已經有230次圍觀

http://coctec.com/docs/python/shhow-post-237820.html