Django(6)

爲何不用_setdjango

 

related_name和related_query_name的區別

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_namerelated_query_nameDjango具備合理的默認值。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上
相關文章
相關標籤/搜索