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