Django Admin:如何用oneToOne关系中的两个模型显示list_display的字段值?

时间:2013-01-14 23:29:15

标签: django admin models one-to-one

我相信我的问题的答案很简单,但我无法在任何地方找到它。这是我的困境。我有两个模型:Member和MemberDetail,它们之间的关系是oneToOne:

class Member(models.Model):
   ID = models.AutoField(primary_key=True)
   FIRST_NAME = models.CharField('First name', max_length=50)
   LAST_NAME = models.CharField('Last name', max_length=50)
   def __unicode__(self):  
      return u'%s %s' % (self.FIRST_NAME, self.LAST_NAME)

class MemberDetail(models.Model):
   member = models.OneToOneField(Member, primary_key=True)
   DATE_OF_BIRTH = models.DateField('Date of birth')
   EMAIL = models.EmailField('E-mail')
   PHONE = models.CharField('Phone', max_length=15)

现在在我的admin.py中,我希望为成员显示包含所有数据的表,如下所示:

class MemberDetailInline(admin.TabularInline):
    model = MemberDetail

class MemberAdmin(admin.ModelAdmin):
    list_display = ("FIRST_NAME", "LAST_NAME", "date_of_birth", "email", "phone")
    inlines = [
        MemberDetailInline,
    ]

admin.site.register(Member, MemberAdmin)

我根本不知道怎么写list_display的“date_of_birth”,“email”和“phone”部分。我能做的最接近的事情是在内联后添加:

def date_of_birth(self, MemberDetail):
    return MemberDetail.DATE_OF_BIRTH
def date_of_birth(self, MemberDetail):
    return MemberDetail.EMAIL
def date_of_birth(self, MemberDetail):
    return MemberDetail.PHONE

但是字段在页面上显示为空。解决办法是什么?感谢。

3 个答案:

答案 0 :(得分:18)

最后!!!我解决了我认为它很简单,但我不得不以其他方式进行并使用多表继承:

models.py
class Member(models.Model):
    ID = models.AutoField(primary_key=True)
    FIRST_NAME = models.CharField('First name', max_length=50)
    LAST_NAME = models.CharField('Last name', max_length=50)

# Using multi table inheritance - automaticly creates one to one field
class MemberDetail(Member):
    DATE_OF_BIRTH = models.DateField('Date of birth')
    EMAIL = models.EmailField('E-mail')
    PHONE = models.CharField('Phone', max_length=15)

现在为admin.py

admin.py
class MemberDetailAdmin(admin.ModelAdmin):
    list_display = ("FIRST_NAME", "LAST_NAME", "DATE_OF_BIRTH", "EMAIL", "PHONE")

admin.site.register(MemberDetail, MemberDetailAdmin)

就是这样。也许,还有其他解决方案,但这对我有好处。

答案 1 :(得分:0)

您应该能够在'member_detail__email'

中执行list_display

因为它是1-1,你应该有一个backref,并使用两个下划线引用相关的字段。

答案 2 :(得分:0)

如果有人偶然发现这个问题/问题,我不知道从 OneToOne 关系访问字段的直接方法,但是,我能够使用以下代码段解决问题。请注意,我可以通过使用两个“_”访问 OneToOne 的字段来访问 list_filter 中的 OneToOne 字段,例如:modelB_fieldOne

@admin.display(description='Date')
    def transaction_date(self, purchase):
        return purchase.transaction.date

list_display = ('product', 'transaction_date')
list_filter = ('product', 'transaction__date')

相关问题