您好,登錄后才能下訂單哦!
這篇文章主要講解了如何使用django orm模塊中的is_delete,內(nèi)容清晰明了,對此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會有幫助。
數(shù)據(jù)庫刪除數(shù)據(jù)咱都知道,簡單的說就是當(dāng)一條數(shù)據(jù)對企業(yè)沒用后,一般人可能會選擇刪除這條數(shù)據(jù)。
但是刪除后,萬一以后又突然有用呢。所以我們這時候會選擇在寫orm模塊的時候,加入is_delete字段
is_delete = models.BooleanField(default=False,verbose_name='是否刪除')
這樣以后咱如果要刪除一條數(shù)據(jù)了,就設(shè)置一下
is_delete=1
就表示這條數(shù)據(jù)在邏輯上刪除了,簡單的說就是你再怎么搜數(shù)據(jù)庫也搜不到了,如果以后還用,就再設(shè)置
is_delete=0
就可以了!
補充知識:django中當(dāng)model設(shè)置了ordering后,使用distinct()和annotate()問題記錄
model類如下,我在class Meta中設(shè)置了ordering = ['-date_create'],即模型對象返回的記錄結(jié)果集是按照這個字段排序的。
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
當(dāng)業(yè)務(wù)有需求如對host_name進(jìn)行分組顯示,在代碼中用到了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}, {'host_name': '點3', '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
可以看到,所得到的結(jié)果并不像我們預(yù)期的一樣,之后把執(zhí)行的sql輸出出來可以看到在group by的時候是對host_name和date_create進(jìn)行分組,原因就是因為我們在model類中設(shè)置了ordering,去掉之后代碼運行正常。
使用distinct和上面的情況類似,就不列出來了。
看完上述內(nèi)容,是不是對如何使用django orm模塊中的is_delete有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。