首先,我对 Python/Django 非常陌生,但多年来我一直在使用其他技术。
在用户可以创建出版物的网站中(让我们以亚马逊为例),我有一个包含基本内容的 Publication
对象,例如标题、详细信息、价格等。
但是,我想包括特定于对象类型的某些属性(布料有尺寸、颜色、男士/女士;汽车有品牌、型号、发动机、变速箱等)。这个想法是使用 Haystack/Elasticsearch 对这些属性进行分面,具体取决于用户正在搜索的内容。
所以,这是基本模型:
# main publication class
class Publication(models.Model):
OBJECT_TYPE = (
('cloth', 'Cloth'),
('electronics', 'Electronics'),
('car', 'Cars'),
)
object_type = models.CharField(max_length=30,
choices=OBJECT_TYPE,
default='electronics')
title = models.CharField()
details = models.CharField()
# other fields...
# Haystack index
class PublicationIndex(indexes.SearchIndex, indexes.Indexable):
text = indexes.CharField(document=True, use_template=True)
object_type = indexes.CharField(faceted=True, model_attr='object_type')
# other fields...
问题是,我应该在哪里存储这些其他属性?
一个选择是让另一个类/模型包含详细信息和出版物的 FK。如果是这样,我应该如何建立索引呢?另一种选择是将所有发布的所有属性放在 Publication
模型中,这将是最简单但可能并不优雅。
另一种选择是继承 CarPublication
、ClothPublication
等。如果是这样,问题是,我如何处理基本内容以避免重复所有屏幕对应每种出版物类型。
我将只有 3 种发布类型,我不认为我会添加更多,所以进行继承,例如,是一个可行的选择(亚马逊有数百个类别,所以它是不同的)。
什么是最好的方法?
仅供引用,使用 Python 3、Django 1.9、Haystack 2.5-dev、Elasticsearch。
最佳答案
django-polymorphic处理得很好。
来自文档:
from polymorphic.models import PolymorphicModel
class Project(PolymorphicModel):
topic = models.CharField(max_length=30)
class ArtProject(Project):
artist = models.CharField(max_length=30)
class ResearchProject(Project):
supervisor = models.CharField(max_length=30)
>>> Project.objects.create(topic="Department Party")
>>> ArtProject.objects.create(topic="Painting with Tim", artist="T. Turner")
>>> ResearchProject.objects.create(topic="Swallow Aerodynamics", supervisor="Dr. Winter")
# Get polymorphic query results:
>>> Project.objects.all()
[ <Project: id 1, topic "Department Party">,
<ArtProject: id 2, topic "Painting with Tim", artist "T. Turner">,
<ResearchProject: id 3, topic "Swallow Aerodynamics", supervisor "Dr. Winter"> ]
关于用于分面的 Python 继承或额外属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34903277/