0

试图从这里的文档中扩展:https ://docs.djangoproject.com/en/1.10/topics/db/models/#extra-fields-on-many-to-many-relationships

上下文更容易理解,Person 对象,M2M 与自身的关系,它定义了两个 Person 之间的“关系类型”,例如 Parent/Child/Engaged

我的模型.py:

RELATIONSHIPS = (

    (0, 'Child'),
    (1, 'Parent'),
    (2, 'Engaged'),
)

class Person(models.Model):
    code = models.AutoField(primary_key=True, verbose_name="Person Code")
    name = models.CharField(max_length=150, blank=True, null=True, verbose_name="Name")

    relationships = models.ManyToManyField(
        'self', 
        through = 'Person_Person', #This lets you define the model that will act as an intermadiary
        symmetrical = False, #This needs to be set with recursive relationships
        )

class Person_Person(models.Model):
    person_1 = models.ForeignKey('Person', on_delete=models.CASCADE, 
        related_name='%(class)s_person_1', verbose_name="Person 1")
    person_2 = models.ForeignKey('Person', on_delete=models.CASCADE,
        related_name='%(class)s_person_2', verbose_name="Person 2")
    relationship_type = models.IntegerField(choices = RELATIONSHIPS, default = 5, verbose_name="Relation")

测试代码:

p1 = Person.objects.create(name = 'Man')
p2 = Person.objects.create(name = 'Woman')

relation = Person_Person(person_1 = p1, person_2 = p2, relationship_type = 2)
reation.save()

print(p1.relationships.all(), p2.relationships.all())
#>><QuerySet [<Person: 108 Woman>]>
#>><QuerySet []>

现在对于问题,p2关系字段的查询集返回空,我理解为什么当您考虑非递归关系时,但在这种情况下调用p2.relationships_set没有意义,即使它确实如此,我怎么知道 aPersonperson_1orperson_2的关系?

欢迎任何建议

4

1 回答 1

1

这似乎是 如何使递归 ManyToManyField 关系在 Django 中具有对称的额外字段的副本? 但我不能标记它们

基本上这在 django 中是不可能的,因为你必须定义symmetrical=False. 相反,您可以选择添加第二个m2m字段。另一个线程对此有一些很好的阅读

于 2017-01-16T21:07:30.887 回答