Python Django的ORM模型继承方法

Python Django的ORM模型继承方法,python,django,django-models,model-inheritance,Python,Django,Django Models,Model Inheritance,我想将事件存储在一个我正在玩弄的web应用程序中,我对每种方法的优缺点都很不确定——广泛使用继承或以更温和的方式使用继承 例如: class Event(models.Model): moment = models.DateTimeField() class UserEvent(Event): user = models.ForeignKey(User) class Meta: abstract = True class UserRegistratio

我想将事件存储在一个我正在玩弄的web应用程序中,我对每种方法的优缺点都很不确定——广泛使用继承或以更温和的方式使用继承

例如:

class Event(models.Model):
    moment = models.DateTimeField()

class UserEvent(Event):
    user = models.ForeignKey(User)
    class Meta:
        abstract = True

class UserRegistrationEvent(UserEvent):
    pass # Nothing to add really, the name of the class indicates it's type

class UserCancellationEvent(UserEvent):
    reason = models.CharField()
感觉我正在疯狂地创建数据库表。这将需要大量的连接来选择内容,并且可能会使查询复杂化。但我觉得它的设计感觉不错

使用更平坦的模型,只是有更多的领域,是否更合理

class Event(models.Model):
    moment = models.DateTimeField()
    user = models.ForeignKey(User, blank=True, null=True)
    type = models.CharField() # 'Registration', 'Cancellation' ...
    reason = models.CharField(blank=True, null=True)
谢谢你的评论,任何人


菲利普。在这种情况下,我看不出深层继承真的能给你带来什么好处:我会选择更平坦的模型,它是一种更简单、更简洁的设计,可能具有更好的性能特征和易访问性。

你可能想试试。通过仅为派生类创建表(包含来自父模型和派生模型的字段),可以实现无连接的继承。这将允许您保留嵌套设计,而不会因所有连接而导致性能损失。

对于这个特定示例,我完全同意。例如,只有当UserRegistrationEvent上有一大堆不适用于常规事件的数据字段时,我才会开始考虑继承。即使在这种情况下,我也会考虑使用抽象基础模型而不是多表继承。抽象出一个字段在其他模型中共享的模型是否被认为是一种好的做法?