【发布时间】:2014-11-25 18:02:11
【问题描述】:
在 django 的多对多关系中突出显示特定关系的最佳方式是什么?
例如,如果我想在基因数据库中突出显示对基因的主要或“最佳”引用,我当前的策略(这似乎有些错误和重复)是在 ManyToManyField 之外使用外键:
from django.db import models
class Gene(models.Model):
name = models.CharField()
primary_reference = models.ForeignKey(Reference)
other_references = models.ManyToManyField(Reference) # doesn't include primary
class Reference(models.Model):
year = models.CharField()
author = models.CharField()
这完成了工作,但现在如果我想获得所有引用,我不能只获得gene.references ...(相反,我需要连接primary_references 和other_references)
另一方面,如果我只创建一个 ManyToManyField 字段
class Gene(models.Model):
name = models.CharField()
referencess = models.ManyToManyField(Reference) # includes primary
获得gene.primary_reference(相反,gene.other_references,不包括主要)的最佳方式是什么?
我想在参考模型中有一个额外的字段,比如“主要参考”的布尔值......但这不起作用,因为作为对我的案例的附加说明:给定的参考可以引用 许多个基因,而只有一个其参考基因的主要参考。
我还应该指出,在这种情况下,确定“主要”参考的标准不是可以从参考模型中的信息(例如发布日期)中计算出来的。
【问题讨论】:
-
primary_reference 是否应该像代码示例中那样是一个单数 ForeignKey?如果是这样,您在这里所拥有的一切都很好,如果您只寻找非主要参考,那么排除该单一参考应该不会太难。如果有多个主要参考文献的可能性,那么这是一个不同的问题(通过
related_through回答)。 -
是的,只有一个 primary_reference。因此,对同一模型同时具有 foreignKey 和 ManyToMany 关系不被认为是不好的做法吗?获得所有参考的最佳方式是
@property def all_references:吗? -
就个人而言,我将
ManyToMany指向所有引用,包括主要引用。如果你想要only 非主要引用,那么你可以构造一个这样的查询:gene.references.exclude(id=gene.primary_reference_id) -
感谢您的帮助!
-
@michaelb:考虑把它写下来作为答案,也许更详细一点,并获得你应得的荣誉。
标签: django django-models foreign-keys many-to-many