Django 解決model 反向引用中的related_name問題
問題:
定義表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是關(guān)聯(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()
以上這篇Django 解決model 反向引用中的related_name問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. css進階學(xué)習(xí) 選擇符2. CSS Hack大全-教你如何區(qū)分出IE6-IE10、FireFox、Chrome、Opera3. css代碼優(yōu)化的12個技巧4. 低版本IE正常運行HTML5+CSS3網(wǎng)站的3種解決方案5. HTML DOM setInterval和clearInterval方法案例詳解6. 詳解瀏覽器的緩存機制7. HTML <!DOCTYPE> 標(biāo)簽8. CSS3實例分享之多重背景的實現(xiàn)(Multiple backgrounds)9. 使用css實現(xiàn)全兼容tooltip提示框10. 告別AJAX實現(xiàn)無刷新提交表單
