У меня есть модель, как это:головоломка относительно объектов Q и внешних ключей
class Thing(models.Model):
property1 = models.IntegerField()
property2 = models.IntegerField()
property3 = models.IntegerField()
class Subthing(models.Model):
subproperty = models.IntegerField()
thing = modelsForeignkey(Thing)
main = models.BooleanField()
У меня есть функция, которая передается список фильтров, где каждый фильтр имеет вид { 'типа ': something,' value ': x}. Эта функция должна возвращать набор результатов Андинг все фильтры вместе:
final_q = Q()
for filter in filters:
q = None
if filter['type'] =='thing-property1':
q = Q(property1=filter['value'])
elif filter['type'] =='thing-property2':
q = Q(property2=filter['value'])
elif filter['type'] =='thing-property2':
q = Q(property3=filter['value'])
if q:
final_q = final_q & q
return Thing.objects.filter(final_q).distinct()
Каждый Subthing имеет логическое свойство «главный». Каждая вещь имеет 1 и только 1 Subthing, где main == True.
теперь мне нужно добавить фильтр, который возвращает все вещи, которые имеют Subthing где main==True
и subproperty==filter['value']
Могу ли я сделать это как часть Q
объекта я строящейся? Если не так? Запрос, который я получаю до моего нового фильтра, может быть довольно большим, поэтому мне нужен метод, который не включает в себя цикл по результатам.
есть опечатка, должны быть модели.ForeignKey() – Evgeny