Я пытаюсь сделать выбор модели с использованием отношения с общим внешним ключом, но он не работает должным образом.Внешний внешний ключ Django и select_related
Я думаю, что лучше иллюстрирована и понятно с кодом
class ModelA(models.Model):
created = models.DateTimeField(auto_now_add=True)
class ModelB(models.Model):
instanceA = models.ForeignKey(ModelA)
content_type = models.ForeignKey(ContentType)
object_id = models.PositiveIntegerField()
content_object = generic.GenericForeignKey()
class ModelC(models.Model):
number = models.PositiveIntegerField()
bInstances = generic.GenericRelation(ModelB)
# Creating an instance of A and C
aInstance=ModelA.objects.create()
cInstance=ModelC.objects.create(number=3)
# Adding instance of C to the B_set of instance A
aInstance.modelb_set.add(content_object=cInstance)
# Select all ModelA instances that have C as content object? Does not work
whatIWant = ModelA.objects.filter(modelb__content_object=modelCInstance)
# Pseudo-solution, requires calling whatIWant.modelA
whatIWant = cInstance.bInstances.select_related("modelA")
Просто чтобы быть ясно, я хотел бы, чтобы эта линия работала: ModelA.objects.filter(modelb__content_object=modelCInstance)
, по-видимому, Джанго не поддерживает использование content_object на фильтровальных отношений.
Заранее благодарен!
Что вы ожидаете? Мы не можем ответить на вопрос, если его нет. –
Я отредактировал сообщение, чтобы сделать его более ясным, извините – Clash