python – 关于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()
我有一个函数,它传递了一个过滤器列表,其中每个过滤器的形式为{‘type’: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都有一个布尔属性’main’. Every Thing有1个且只有1个Subthing,其中main == True.
我现在需要添加过滤器,返回所有具有Subthing的东西,其中main == True和subproperty == filter [‘value’]
我可以将此作为我正在构建的Q对象的一部分吗?如果不是怎么回事?我在新过滤器之前得到的查询集可能非常大,所以我想要一个不涉及循环结果的方法.
解决方法:
如果你明确地给你的Subthings在他们与Thing的关系中给出了“related_name”,那就更容易理解了
class Subthing(models.Model):
...
thing = models.ForeignKey(Thing, related_name='subthings')
...
现在,您使用Django join syntax来构建Q对象:
Q(subthings__main=True) & Q(subthings__subproperty=filter['value'])
反向关系具有默认名称’subthing_set’,但我发现如果你给它一个更好的名字,比如’subthings’,它会更容易理解.
标签:python,django,django-queryset,django-models,django-q 来源: https://codeday.me/bug/20190701/1344029.html