Django的双外键?

时间:2011-03-02 00:34:23

标签: sql django foreign-keys

无论如何在Django中建模双外键?

例如,如果我有表:音频,叠加,HTML 和表:timeline_item,它有一个字段id,以及一个字段类别,它指定音频,叠加或html ......

有谁知道我会如何在Django中进行建模?或者如果可能的话?

3 个答案:

答案 0 :(得分:8)

听起来像是多态关联。也许你可以使用ContentTypes框架解决Django的通用关系问题。

答案 1 :(得分:2)

外键是 TWO 表之间的引用约束,因此您实际上不能有一列引用3个不同表上的3列。

请参阅:http://en.wikipedia.org/wiki/Foreign_key

你觉得它有点不同,我相信代码最好展示:

class Category(models.Model):
  TYPES = (
    ('audio', 'audio'),
    ('overlay', 'overlay'),
    ('html', 'html'),
  )
  type = models.CharField(choices=TYPES)

class Audio(models.Model):
  category = models.OneToOneField(Category)
  additional_column_for_audio = models. ...
  #...
# same for overlay and html

class Item(models.Model):
  # id is automatically added
  category = models.ForeignKey(Category)

然后您可以迭代项目并执行以下操作:

{% for item in items %}
  {% if item.category.type == "audio" %}
     {{ item.category.audio.additional_column_for_audio }}
  {% endif %}
{% endfor %}

答案 2 :(得分:0)

我最终做的是使用这个: http://docs.djangoproject.com/en/1.0/topics/db/models/#id7

在此之前我使用的是另一个在类中定义的方法,该方法需要2个外键,它们只是将字段字典映射到它们的类并返回该对象类型。