我目前正在 Django 中开发一个模型,其中一个模型可以具有多种不同的特征,具体取决于它是什么类型的对象。因此,假设我们有一个名为哺乳动物的模型,它可以是大象或海豚(分别具有自己的特征“tusk_length”和“flipper_length”)。
基本的 OOP 原则高喊“多态性”,我倾向于同意。但是,由于我是 Django 的新手,我首先想知道这是否是在 Django 中执行此操作的最佳方法。我听说过很多例子,有些人对单一巨型模型表现出了自己的偏好
我已经尝试使用 GenericForeignKeys,如下所述:如何将 Django 的 GenericForeignKey 限制为模型列表? https://stackoverflow.com/questions/6335986/how-can-i-restrict-djangos-genericforeignkey-to-a-list-of-models。虽然这个解决方案工作得很好,但我不喜欢无法过滤,而且这种关系只是一种方式。也就是说,虽然您可以从 Mammal 对象获取 Dolphin,但无法从 Dolphin 获取 Mammal 对象。
所以,这是我的两个选择:
选择A:
from django.db import models
class Mammal(models.Model):
hair_length = models.IntegerField()
tusk_length = models.IntegerField()
flipper_length = models.IntegerField()
animal_type = models.CharField(max_length = 15, choices = ["Elephant", "Dolphin"]
选项B:
from django.db import models
class Mammal(models.Model):
hair_length = models.IntegerField()
class Elephant(Mammal):
tusk_length = models.IntegerField()
class Dolphin(Mammal):
flipper_length = models.IntegerField()
据我了解,选择 B 在查询和列出所有大象或海豚时具有更好的代码优势。然而,我注意到,如果不将animal_type放入类中,从哺乳动物列表中获取所有大象(是否有查询?)并不那么简单,默认情况下依赖于类。
这导致了我在多态性方面看到的另一个问题,这个问题不会出现在上面的示例或我的应用程序中,但值得一提的是,在不完全删除海豚的情况下将海豚对象编辑为大象是很困难的。
总的来说,有什么普遍的偏好,或者有什么我不应该使用多态性的重要原因吗?