related_name
將成爲相關對象的屬性,容許您使用外鍵對模型進行「倒退」。例如,若是ModelA
有像下面這樣的字段,那麼model_b = ForeignKeyField(ModelB, related_name='model_as')
這將使您可以經過去訪問ModelA
與您的ModelB
實例相關的實例model_b_instance.model_as.all()
。請注意,這一般是用複數形式編寫的外鍵,由於外鍵是一對多關係,而且該等式的許多方面是具備在其上聲明的外鍵字段的模型。post
文檔中進一步的解釋是有幫助的。https://docs.djangoproject.com/en/1.10/topics/db/queries/#backwards-related-objectsspa
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具備合理的默認值。code
# 統計出每一個出版社買的最便宜的書的價格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上