溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Django怎么解決model反向引用中的related_name問題

發(fā)布時間:2020-07-23 11:44:50 來源:億速云 閱讀:206 作者:小豬 欄目:開發(fā)技術(shù)

這篇文章主要講解了Django怎么解決model反向引用中的related_name問題,內(nèi)容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。

問題:

定義表Apple:

class Apple( models.Model):
  origin_level = models.ForeignKey(AppleLevel)
  new_level = models.ForeignKey(AppleLevel)

出現(xiàn)如下問題:

monitor.apple: Accessor for field ‘origin_level' clashes with related field ‘AppleLevel.apple_set'. Add a related_name argument to the definition for ‘origin_level'.

monitor.apple: Accessor for field ‘new_level' clashes with related field ‘AppleLevel.apple_set'. Add a related_name argument to the definition for ‘new_level'.

原因:

一個數(shù)據(jù)表同時兩次外鍵引用另一個表,出現(xiàn)重名問題。

解決辦法:

使用related_name屬性定義名稱(related_name是關聯(lián)對象反向引用描述符)。

具體修改代碼如下:

class Apple( models.Model):
  origin_level = models.ForeignKey(AppleLevel, related_name='orgin_level_appleset')
  new_level = models.ForeignKey(AppleLevel, related_name='new_level_appleset')

related_name使用之后,有什么用處呢?

用處就是:

通過AppleLevel可以得到引用自身的Apple對象。

例如,

通過origin_level引用AppleLevel 中id為12的Apple的所有對象

AppleLevel.object.get(id=12).origin_level_appleset.objects.all()

通過new_level引用AppleLevel 中id為12的Apple的所有對象

AppleLevel.object.get(id=12).new_level_appleset.objects.all()

看完上述內(nèi)容,是不是對Django怎么解決model反向引用中的related_name問題有進一步的了解,如果還想學習更多內(nèi)容,歡迎關注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI