外键Django模型

时间:2013-02-02 15:43:28

标签: python django django-models

我正在尝试创建3个模型; PersonAddressAnniversy。计划是为每个人提供一个地址和一个周年纪念。但是每个地址和周年纪念都可以有多个人。

到目前为止,我有以下内容,但我认为OneToMany(foreign key)关系可能是错误的。即每个地址可以有一个人,但每个人可以有多个地址。

from django.db import models

class Person(models.Model):
    name = models.CharField(max_length=50)
    birthday = models.DateField()

    def __unicode__(self):
        return u'%s' % (self.name)

class Address(models.Model):
    person = models.ForeignKey(Person)
    address = models.CharField(max_length=150)

    def __unicode__(self):
        return u'%s' % (self.address)

class Anniversy(models.Model):
    person = models.ForeignKey(Person)
    anniversy = models.DateField()

    def __unicode__(self):
        return u'%s' % (self.anniversy)

2 个答案:

答案 0 :(得分:66)

你以相反的方式创造关系;将外键添加到Person类型以创建多对一关系:

class Person(models.Model):
    name = models.CharField(max_length=50)
    birthday = models.DateField()
    anniversary = models.ForeignKey(
        Anniversary, on_delete=models.CASCADE)
    address = models.ForeignKey(
        Address, on_delete=models.CASCADE)

class Address(models.Model):
    line1 = models.CharField(max_length=150)
    line2 = models.CharField(max_length=150)
    postalcode = models.CharField(max_length=10)
    city = models.CharField(max_length=150)
    country = models.CharField(max_length=150)

class Anniversary(models.Model):
    date = models.DateField()

任何一个人只能连接到一个地址和一个周年纪念日,但地址和纪念日可以从多个Person条目中引用。

AnniversaryAddress个对象也将被给予反向的向后关系;默认情况下,它将被称为person_set,但如果需要,您可以配置不同的名称。请参阅查询文档中的以下relationships "backward"

答案 1 :(得分:1)

我建议,如果使用基于应用程序的方法来分离逻辑关注点,则将字符串模型引用用于ForeignKey关系是一种更好的做法。

因此,请扩展Martijn Pieters的答案:

class Person(models.Model):
    name = models.CharField(max_length=50)
    birthday = models.DateField()
    anniversary = models.ForeignKey(
        'app_label.Anniversary', on_delete=models.CASCADE)
    address = models.ForeignKey(
        'app_label.Address', on_delete=models.CASCADE)

class Address(models.Model):
    line1 = models.CharField(max_length=150)
    line2 = models.CharField(max_length=150)
    postalcode = models.CharField(max_length=10)
    city = models.CharField(max_length=150)
    country = models.CharField(max_length=150)

class Anniversary(models.Model):
    date = models.DateField()