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ù)表同時(shí)兩次外鍵引用另一個表,出現(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. ASP基礎(chǔ)知識VBScript基本元素講解2. Python 利用Entrez庫篩選下載PubMed文獻(xiàn)摘要的示例3. Python 合并拼接字符串的方法4. Python 制作查詢商品歷史價(jià)格的小工具5. Python 如何調(diào)試程序崩潰錯誤6. Python sublime安裝及配置過程詳解7. python使用jenkins發(fā)送企業(yè)微信通知的實(shí)現(xiàn)8. Linux刪除系統(tǒng)自帶版本Python過程詳解9. ASP.NET MVC使用jQuery ui的progressbar實(shí)現(xiàn)進(jìn)度條10. Python3 json模塊之編碼解碼方法講解

網(wǎng)公網(wǎng)安備