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