gpt4 book ai didi

python - 使用 Django 为抽象基类设置外键

转载 作者:IT老高 更新时间:2023-10-28 22:01:00 25 4
gpt4 key购买 nike

我已将两个类中的公共(public)属性分解为一个抽象基类,但是我有另一个模型需要引用这些类中的任何一个。不能引用 ABC,因为它实际上没有数据库表。

下面的例子应该能说明我的问题:

class Answer(models.Model):
ovramt = models.ForeignKey("Ovramt")
question = models.ForeignKey("Question")
answer = models.CharField(max_length=3, choices=(("yes","yes"),("no","no") ("NA","N/A"))
likelihood = models.IntegerField(choices=LIKELY_CHOICES)
consequence = models.IntegerField(choices=CONSEQUENCE_CHOICES)

class Meta:
abstract = True

class Answer_A(Answer):
resident = models.ForeignKey("Resident")
def __unicode__(self):
return u"%s - %s - %s" %(self.ovramt.ssa.name, self.resident, self.question)

class Answer_B(Answer):
def __unicode__(self):
return u"%s - %s" %(self.ovramt.ssa.name, self.question)

class Answer_Risk(models.Model):
answer = models.ForeignKey("Answer")
risk = models.CharField(max_length=200)

def __unicode__(self):
return self.risk

Answer_A 和 Answer_B 略有不同,因为 Answer_A 还需要与另一个表建立 FK 关系。 Answer_B 以后可能还需要一些特定的属性。如果我让 Answer_B 成为父类(super class) - 并且拥有 Answer_A 子类或组合它,问题仍然存在。

无论是 Answer_A 还是 Answer_B,“风险”都是相同的。我还有其他模型需要引用“答案”,无论其子类型如何。如何才能做到这一点?不管它是什么子类型,如何引用一个类型?

更新:
我试图避免加入操作,但我认为我做不到。是否值得在所有“答案”中引用“居民”并在需要时将其取消?或者这被认为是非常糟糕的做法?

最佳答案

一个 generic relation似乎是解决方案。但这会让事情变得更加复杂。

在我看来;您的模型结构已经比必要的复杂。我会简单地将所有三个 Answer 模型合并为一个。这样:

  • Answer_Risk 无需修改即可工作。
  • 如果是 Answer_A,您可以将 resident 设置为 None (NULL)。
  • 您可以根据 resident == None 返回不同的字符串表示形式。 (换句话说;相同的功能)

还有一件事;你的答案可能有不止一种风险吗?如果他们没有风险或只有一种风险,您应该考虑以下替代实现:

我主要关心的既不是数据库结构也不是性能(尽管这些更改应该会提高性能),而是代码可维护性

关于python - 使用 Django 为抽象基类设置外键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/367461/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com