4

我想将事件存储在我正在玩弄的 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)

感谢您对此的评论,任何人。

菲利普

4

2 回答 2

6

平面优于嵌套。在这种情况下,我不认为“深度继承”真的会给你带来任何好处:我会选择更扁平的模型,因为它是一种更简单、更简单的设计,可能具有更好的性能特征和易于访问。

于 2009-09-04T21:02:05.110 回答
2

您可能想尝试Abstract base models。这实现了没有连接的继承,只为派生类创建表,包含来自父模型和派生模型的字段。这将允许您保留嵌套设计,而不会影响所有这些连接的性能。

于 2009-09-04T22:07:25.523 回答