日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

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

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

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

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

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

假設(shè)是一本數(shù)學書,有5個章節(jié),每個章節(jié)里有數(shù)量不等的習題,

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

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

# 按我的理解是取問題非空的章節(jié)數(shù)# 類似于問爺爺有幾個孫子,沒辦法跨輩,就按一個孫子對應(yīng)一個爸爸來取(有重復)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='是否通過')# 章節(jié)class Chapter(models.Model): _id = models.IntegerField(verbose_name='編號') title = models.CharField() problem = models.ManyToManyField(Problem) pass_rate = models.IntegerField(verbose_name='通關(guān)率') @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='章節(jié)') 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設(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

當業(yè)務(wù)有需求如對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

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

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

以上這篇Django多層嵌套ManyToMany字段ORM操作詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標簽: Django
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
极品av在线| 欧美日韩伊人| 国产一区一一区高清不卡| 精品国产亚洲日本| 99精品美女| 亚洲免费观看| 日韩一区免费| 欧美国产另类| 美女精品一区二区| 日韩a一区二区| 91tv亚洲精品香蕉国产一区| 国产精品久久久久久久久久齐齐| 麻豆高清免费国产一区| 欧美sss在线视频| 亚洲国产一区二区三区在线播放| 午夜国产精品视频免费体验区| 日韩制服丝袜av| 蜜臀av在线播放一区二区三区| 亚洲欧美网站在线观看| 日韩高清不卡在线| 日韩欧美精品综合| 蜜臀久久99精品久久久久宅男 | 波多野结衣一区| 国产韩日影视精品| 精品久久视频| 欧美专区18| 久久av综合| 欧美日韩在线网站| 精品一区二区三区中文字幕 | 美女黄网久久| 精品亚洲自拍| 国产精品美女久久久| 国产精品午夜一区二区三区| 欧美精品三级在线| 欧美日韩一二| 亚洲精品免费观看| 久久精品一区二区不卡| 麻豆一区二区在线| 亚洲专区视频| 国产剧情在线观看一区| 久久国产精品毛片| 在线成人动漫av| 不卡在线一区| 国产极品久久久久久久久波多结野 | 91精品高清| 国产精品白丝久久av网站| 伊人久久成人| 日韩欧美视频专区| 日韩欧美一区二区三区免费观看| 精品五月天堂| 国产中文欧美日韩在线| 日韩在线成人| 日韩中文av| 日韩av不卡一区二区| 亚洲婷婷丁香| 久久亚洲美女| 亚洲一区观看| 日韩一区二区三区在线看| 免费久久精品视频| 日韩精品首页| 蜜桃国内精品久久久久软件9| yellow在线观看网址| 日韩大片免费观看| 久久精品影视| 欧美特黄视频| 五月综合激情| 亚洲精品精选| 免费在线播放第一区高清av| 麻豆国产欧美一区二区三区 | 国产日韩高清一区二区三区在线 | 欧美一级网址| 欧美日韩在线网站| 久久久久美女| 亚洲精品123区| 欧美亚洲色图校园春色| 亚洲狼人精品一区二区三区| 日韩中文字幕无砖| 精品一区91| 成人片免费看| 六月丁香综合| 久久国产精品免费精品3p | 国产精品s色| 韩国久久久久久| 天堂中文av在线资源库| 精品国产乱码久久久| 天堂中文在线播放| 午夜在线视频观看日韩17c| 欧美一区91| 亚洲成人日韩| 亚洲三级在线| 中文一区一区三区高中清不卡免费| 精品亚洲免a| 久久久久网站| 日本免费一区二区视频| 首页国产精品| 国产免费播放一区二区| 在线精品福利| 成人久久一区| 久久不见久久见中文字幕免费| 九色porny丨国产首页在线| 中文亚洲免费| 日本一区二区免费高清| 亚洲激情黄色| 美女视频黄免费的久久| 爽爽淫人综合网网站| 天堂√中文最新版在线| 日本午夜精品久久久久| 国产国产精品| 欧洲精品一区二区三区| 日韩精品五月天| 日韩视频一区| 综合亚洲自拍| 石原莉奈在线亚洲二区| 丝袜av一区| 荡女精品导航| 日本综合视频| 蜜臀久久久99精品久久久久久| 午夜av不卡| 日产精品一区二区| av综合电影网站| 日韩一区二区三区在线免费观看| 国产精品激情| 欧美日本二区| 青青在线精品| 久久午夜精品一区二区| 激情综合网址| 偷拍精品精品一区二区三区| 成人午夜网址| 久久久9色精品国产一区二区三区| 狠狠久久伊人中文字幕| 天堂va蜜桃一区二区三区| 人人精品亚洲| 九色porny丨国产首页在线| 日韩av电影一区| 日韩激情一区二区| 香蕉久久久久久| 国产日韩欧美一区| 亚洲一级在线| 久久久久久美女精品| 色网在线免费观看| 亚洲欧美专区| 国语对白精品一区二区| 国产高清不卡| 色婷婷精品视频| 婷婷久久一区| 99精品在线| 在线精品国产亚洲| 日本成人一区二区| 日韩av网站在线观看| 国产一二在线播放| 欧美成人精品| 日韩精品久久久久久| 国际精品欧美精品| 性感美女一区二区在线观看| 亚洲激情另类| 精品国产三区在线| 不卡视频在线| 国产精品网站在线看| a国产在线视频| 亚洲午夜久久久久久尤物| 亚洲综合婷婷| 国产一区二区三区四区二区| 欧美日韩色图| 日韩一区二区三区四区五区| 卡一卡二国产精品| 日韩午夜av| 老牛影视精品| 亚洲免费影院| 久久av电影| 中文视频一区| 欧美日韩中文一区二区| 欧美激情 亚洲a∨综合| 在线视频亚洲| 中文另类视频| 国产精品手机在线播放| 国产日韩免费| 日韩精品欧美大片| 激情自拍一区| 成人在线视频区| 久久av一区| 久久久成人网| 国产精品手机在线播放| 亚洲婷婷免费| 国产在线观看91一区二区三区| 欧美天堂在线| 日韩不卡一区二区| 亚洲一区日韩| 久久中文字幕av| 久久精品国产久精国产| 免费视频久久| 你懂的亚洲视频| 国产精品s色| 日韩一区精品视频| 免费视频一区二区| 鲁大师影院一区二区三区| 久久人人88| 欧美日韩中文一区二区| 午夜欧美精品| 亚洲少妇诱惑| 国产精品丝袜在线播放|