国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

django orm模塊中的 is_delete用法

瀏覽:2日期:2024-10-02 14:43:54

數(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

就可以了!

補(bǔ)充知識: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和上面的情況類似,就不列出來了。

以上這篇django orm模塊中的 is_delete用法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Django
相關(guān)文章:
主站蜘蛛池模板: 久艹视频在线免费观看 | 国产精品1区 2区 3区 | 香港三级网站 | 久久精品国产影库免费看 | 成人黄色免费看 | 亚洲偷偷自拍 | 日韩精品a | 一级aaaaaa毛片免费同男同女 | 亚洲欧美精品一区天堂久久 | 伊人婷婷色香五月综合缴激情 | 美女亚洲视频 | 爱久久精品国产 | 国内交换一区二区三区 | 免费一级特黄特色黄大任片 | 日本免费毛片 | 欧美日韩在线播放一区二区三区 | 亚洲欧美视频网站 | 亚洲午夜在线 | 永久精品免费影院在线观看网站 | 欧美成人性色大片在线观看 | 99爱视频| 成人精品一区二区www | 成年网站免费 | 欧美成人性做爰 | 欧美日韩精品一区二区视频在线观看 | 美国一级毛片片aa成人 | 狠狠色综合网站久久久久久久 | 尤蜜网站在线进入免费 | 中文字幕波多野不卡一区 | 99视频在线免费观看 | 久草免费公开视频 | 黄色三级网站免费 | 欧美久久视频 | 国产亚洲精品久久久久91网站 | 色偷偷成人网免费视频男人的天堂 | 国产成a人片在线观看视频 国产成版人视频网站免费下 | 日韩中文字幕在线看 | 成人永久福利在线观看不卡 | 成年人免费看 | 国产手机在线视频放线视频 | 91在线精品亚洲一区二区 |