亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

Django多層嵌套ManyToMany字段ORM操作詳解

瀏覽:2日期:2024-10-04 18:22:36

在用django寫項目時,遇到了許多場景,關于ORM操作獲取數據的,但是不好描述出來,百度搜索關鍵詞都不知道該怎么搜,導致一個人鼓搗了好久。這里細化下問題,還原場景,記錄踩下的坑

首先先列舉model,我舉些生活中的例子,更方便理解問題

# 習題class Problem(models.Model): desc = models.CharField() answer = models.TextField() is_pass = models.BooleanField(default=False, verbose_name='是否通過')# 章節class Chapter(models.Model): _id = models.IntegerField(verbose_name='編號') title = models.CharField() problem = models.ManyToManyField(Problem) pass_rate = models.IntegerField(verbose_name='通關率')# 書籍 class Book(models.Model): title = models.CharField() desc = models.TextField() chapter = models.ManyToManyField(Chapter,verbose_name='章節') speed = models.IntegerField(verbose_name='學習進度', default=0)

假設是一本數學書,有5個章節,每個章節里有數量不等的習題,

即book與chapter是多對多,chapter與problem也是多對多

場景一: 書籍下的所有習題

# 按我的理解是取問題非空的章節數# 類似于問爺爺有幾個孫子,沒辦法跨輩,就按一個孫子對應一個爸爸來取(有重復)book.chapter.filter(problem___id__isnull=False).count()

場景二:書籍下所有通過的習題

book.chapter.filter(problem__is_pass=True).count()

場景三: 判斷某個問題是否在這本書里

def problem_in_ladder(book, problem): for i in book.chapter.all(): if problem in i.problem.all():return True return False

盡可能的減少view中對models的取值操作,所以把上面幾個場景方法寫在models類中

最終的models

# 習題class Problem(models.Model): desc = models.CharField() answer = models.TextField() is_pass = models.BooleanField(default=False, verbose_name='是否通過')# 章節class Chapter(models.Model): _id = models.IntegerField(verbose_name='編號') title = models.CharField() problem = models.ManyToManyField(Problem) pass_rate = models.IntegerField(verbose_name='通關率') @property def items(self): return self.problem.count() @property def pass_problem(self): return self.problem.filter(is_pass=True).count() # 書籍 class Book(models.Model): title = models.CharField() desc = models.TextField() chapter = models.ManyToManyField(Chapter,verbose_name='章節') speed = models.IntegerField(verbose_name='學習進度', default=0) @property def chapters(self): return self.chapter.count() @property def pass_count(self): return self.chapter.filter(problem__is_pass=True).count() @property def items(self): return self.chapter.filter(problem___id__isnull=False).count()

補充知識: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多層嵌套ManyToMany字段ORM操作詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Django
相關文章:
主站蜘蛛池模板: 亚洲精品亚洲人成人网 | 欧美成视频人免费淫片 | 国产精品高清一区二区三区不卡 | 国产91区精品福利在线社区 | 久久精品福利视频在线观看 | 日本成人一区二区 | 亚洲人成一区二区三区 | 免费看黄资源大全高清 | 奇米影视亚洲狠狠色 | 黄色片在线免费 | 国产黄色大片网站 | 亚洲自拍第二页 | 亚洲女同视频 | 欧美精品亚洲一区二区在线播放 | 欧美片欧美日韩国产综合片 | 久久er国产精品免费观看2 | 在线小视频国产 | 精品视频h | 成人精品视频在线观看播放 | 久久厕所精品国产精品亚洲 | 久久亚洲国产精品 | 九九视频免费在线 | 精品亚洲视频在线观看 | 亚洲天堂久久精品成人 | 欧美电影精品久久久久 | 91美女视频在线 | 国产美女一级视频 | 亚洲精品永久www嫩草 | 一级黄色片在线观看 | 午夜一区二区免费视频 | 久久男人网| 日本精品久久久久中文字幕 1 | 国产欧美日韩一区二区三区 | 91精彩视频在线观看 | 日本视频高清免费观看xxx | 国产精品密播放国产免费看 | 亚洲精品国产成人中文 | 国产伦一区二区三区四区久久 | 久久草国产 | 成年性视频bbixx | 亚洲国产色婷婷精品综合在线观看 |