国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

django orm模塊中的 is_delete用法

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

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

但是刪除后,萬一以后又突然有用呢。所以我們這時候會選擇在寫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}, {’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

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

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

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

標簽: Django
相關文章:
主站蜘蛛池模板: 那坡县| 化隆| 泰安市| 海城市| 景德镇市| 阜平县| 那曲县| 鹤岗市| 库尔勒市| 峨边| 吐鲁番市| 石家庄市| 昌江| 堆龙德庆县| 社旗县| 治多县| 五指山市| 永宁县| 旌德县| 德令哈市| 吴忠市| 孟村| 德兴市| 梁河县| 孝义市| 如东县| 获嘉县| 来宾市| 华阴市| 屏东县| 嘉义县| 安塞县| 安丘市| 苏尼特右旗| 怀宁县| 融水| 车险| 隆安县| 罗甸县| 科技| 大安市|