您好,登錄后才能下訂單哦!
這篇文章主要講解了Django怎么解決model反向引用中的related_name問題,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。
問題:
定義表Apple:
class Apple( models.Model): origin_level = models.ForeignKey(AppleLevel) new_level = models.ForeignKey(AppleLevel)
出現如下問題:
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'.
原因:
一個數據表同時兩次外鍵引用另一個表,出現重名問題。
解決辦法:
使用related_name屬性定義名稱(related_name是關聯對象反向引用描述符)。
具體修改代碼如下:
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()
看完上述內容,是不是對Django怎么解決model反向引用中的related_name問題有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。