Django(6)
為什么不用_set
?
related_name和related_query_name的區(qū)別related_name將成為相關(guān)對(duì)象的屬性,允許您使用外鍵對(duì)模型進(jìn)行“倒退”。例如,如果ModelA有像下面這樣的字段,那么model_b = ForeignKeyField(ModelB, related_name='model_as')這將使您能夠通過(guò)去訪問(wèn)ModelA與您的ModelB實(shí)例相關(guān)的實(shí)例model_b_instance.model_as.all()。請(qǐng)注意,這通常是用復(fù)數(shù)形式編寫的外鍵,因?yàn)橥怄I是一對(duì)多關(guān)系,并且該等式的許多方面是具有在其上聲明的外鍵字段的模型。
文檔中進(jìn)一步的解釋是有幫助的。https://docs.djangoproject.com/en/1.10/topics/db/queries/#backwards-related-objects
related_query_name用于Django查詢集。它允許您過(guò)濾外鍵相關(guān)字段的反向關(guān)系。為了繼續(xù)我們的例子 - 將一個(gè)字段設(shè)置Model A為:?model_b = ForeignKeyField(ModelB, related_query_name='model_a')將使您可以model_a用作查詢集中的查找參數(shù),如:ModelB.objects.filter(model_a=whatever)。使用單數(shù)形式更常見related_query_name。正如文檔所說(shuō),沒有必要指定兩者(或其中之一)related_name和related_query_name。Django具有合理的默認(rèn)值。
?
# 統(tǒng)計(jì)出每個(gè)出版社買的最便宜的書的價(jià)格
ret=models.Publisher.objects.first().book_set.all()
ret=models.Publisher.objects.get(id=1).books.all()
book_set可以用books代替related_name用在get上
ret=models.Publisher.objects.filter().annotate(c=Min('zhangzhao__price')).values('name','zhangzhao__title','c')
print(ret)
book_set可以用books代替related_query_name用在filter上
轉(zhuǎn)載于:https://www.cnblogs.com/shanjinghao/p/9207824.html
總結(jié)
- 上一篇: js - 执行上下文和作用域以及闭包
- 下一篇: 新开通博客园,纪念一下。