无论如何在Django中建模双外键?
例如,如果我有表:音频,叠加,HTML 和表:timeline_item,它有一个字段id,以及一个字段类别,它指定音频,叠加或html ......
有谁知道我会如何在Django中进行建模?或者如果可能的话?
答案 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个外键,它们只是将字段字典映射到它们的类并返回该对象类型。