欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2020年05月19日 10:10:02   作者:宅神kin  
這篇文章主要介紹了Django多層嵌套ManyToMany字段ORM操作詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

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

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

# 習(xí)題
class Problem(models.Model):
  desc = models.CharField()
  answer = models.TextField()
  is_pass = models.BooleanField(default=False, verbose_name="是否通過(guò)")

# 章節(jié)
class Chapter(models.Model):
  _id = models.IntegerField(verbose_name="編號(hào)")
  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="學(xué)習(xí)進(jìn)度", default=0)

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

即book與chapter是多對(duì)多,chapter與problem也是多對(duì)多

場(chǎng)景一: 書籍下的所有習(xí)題

# 按我的理解是取問(wèn)題非空的章節(jié)數(shù)
# 類似于問(wèn)爺爺有幾個(gè)孫子,沒(méi)辦法跨輩,就按一個(gè)孫子對(duì)應(yīng)一個(gè)爸爸來(lái)?。ㄓ兄貜?fù))
book.chapter.filter(problem___id__isnull=False).count()

場(chǎng)景二:書籍下所有通過(guò)的習(xí)題

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

場(chǎng)景三: 判斷某個(gè)問(wèn)題是否在這本書里

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

盡可能的減少view中對(duì)models的取值操作,所以把上面幾個(gè)場(chǎng)景方法寫在models類中

最終的models

# 習(xí)題
class Problem(models.Model):
  desc = models.CharField()
  answer = models.TextField()
  is_pass = models.BooleanField(default=False, verbose_name="是否通過(guò)")

# 章節(jié)
class Chapter(models.Model):
  _id = models.IntegerField(verbose_name="編號(hào)")
  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="學(xué)習(xí)進(jìn)度", 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()

補(bǔ)充知識(shí):django中當(dāng)model設(shè)置了ordering后,使用distinct()和annotate()問(wèn)題記錄

model類如下,我在class Meta中設(shè)置了ordering = ['-date_create'],即模型對(duì)象返回的記錄結(jié)果集是按照這個(gè)字段排序的。

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ù)有需求如對(duì)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': '點(diǎn)2', 'dcount': 1}, {'host_name': '點(diǎn)3', 'dcount': 2}, {'host_name': '點(diǎn)2', 'dcount': 1}, {'host_name': '點(diǎn)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輸出出來(lái)可以看到在group by的時(shí)候是對(duì)host_name和date_create進(jìn)行分組,原因就是因?yàn)槲覀冊(cè)趍odel類中設(shè)置了ordering,去掉之后代碼運(yùn)行正常。

使用distinct和上面的情況類似,就不列出來(lái)了。

以上這篇Django多層嵌套ManyToMany字段ORM操作詳解就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python+Turtle繪制航海王草帽路飛詳解

    Python+Turtle繪制航海王草帽路飛詳解

    turtle庫(kù)是一個(gè)點(diǎn)線面的簡(jiǎn)單圖像庫(kù),在Python2.6之后被引入進(jìn)來(lái),能夠完成一些比較簡(jiǎn)單的幾何圖像可視化。本文將利用turtle繪制一個(gè)可愛(ài)的草帽路飛,感興趣的可以試一試
    2022-03-03
  • Python中最好用的json庫(kù)orjson用法詳解

    Python中最好用的json庫(kù)orjson用法詳解

    orjson是一個(gè)用于python的快速、正確的json庫(kù),它的基準(zhǔn)是 json最快的python庫(kù),具有全面的單元、集成和互操作性測(cè)試,下面這篇文章主要給大家介紹了關(guān)于Python中最好用的json庫(kù)orjson用法的相關(guān)資料,需要的朋友可以參考下
    2022-06-06
  • Python使用微信SDK實(shí)現(xiàn)的微信支付功能示例

    Python使用微信SDK實(shí)現(xiàn)的微信支付功能示例

    這篇文章主要介紹了Python使用微信SDK實(shí)現(xiàn)的微信支付功能,結(jié)合實(shí)例形式分析了Python調(diào)用微信SDK接口實(shí)現(xiàn)微信支付功能的具體步驟與相關(guān)操作技巧,需要的朋友可以參考下
    2017-06-06
  • pytorch實(shí)現(xiàn)用Resnet提取特征并保存為txt文件的方法

    pytorch實(shí)現(xiàn)用Resnet提取特征并保存為txt文件的方法

    今天小編大家分享一篇pytorch實(shí)現(xiàn)用Resnet提取特征并保存為txt文件的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-08-08
  • Python中輸入和輸出(打?。?shù)據(jù)實(shí)例方法

    Python中輸入和輸出(打?。?shù)據(jù)實(shí)例方法

    在本篇文章里小編給大家整理的是關(guān)于Python中輸入和輸出(打印)數(shù)據(jù)實(shí)例方法以及相關(guān)知識(shí)點(diǎn),有需要的朋友們參考下。
    2019-10-10
  • Python實(shí)現(xiàn)FIFO緩存置換算法

    Python實(shí)現(xiàn)FIFO緩存置換算法

    這篇文章主要為大家詳細(xì)介紹了Python實(shí)現(xiàn)FIFO(先進(jìn)先出)緩存置換算法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • python實(shí)現(xiàn)門限回歸方式

    python實(shí)現(xiàn)門限回歸方式

    今天小編就為大家分享一篇python實(shí)現(xiàn)門限回歸方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-02-02
  • Pytorch 保存模型生成圖片方式

    Pytorch 保存模型生成圖片方式

    今天小編就為大家分享一篇Pytorch 保存模型生成圖片方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-01-01
  • 最新評(píng)論