1. 程式人生 > 程式設計 >Django 解決model 反向引用中的related_name問題

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問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。