如何使用任意数量的 OR 子句形成 Django 查询?
How do I form a Django query with an arbitrary number of OR clauses?
我在 Python 3.7 中使用 Django 2.0。如果字段至少包含数组中的一个字符串,我想编写一个 returns 结果的查询,因此我想设置一个 OR 查询。这个我试过了
class CoopManager(models.Manager):
...
# Meant to look up coops case-insensitively by part of a type
def contains_type(self, types_arr):
queryset = Coop.objects.all()
for type in types_arr:
queryset = queryset.filter(type__name__icontains=type)
print(queryset.query)
return queryset
但是,这会产生一个将子句与在一起的查询。我如何执行上述操作,但使用 OR 而不是 AND 连接所有子句?
我正在使用 MySql 5.7,但我想知道一个独立于数据库的解决方案(如果存在的话)。
您可以创建一个构造此析取的 Q
对象:
from django.db.models import Q
filter = Q(
*[('type__name__icontains', type) for type in types_arr],
<b>_connector=Q.OR</b>
)
queryset = Coop.objects.filter(filter)
这里 filter
是一个 Q
对象,它是所有 type__name__icontains=type
过滤器的析取。
我在 Python 3.7 中使用 Django 2.0。如果字段至少包含数组中的一个字符串,我想编写一个 returns 结果的查询,因此我想设置一个 OR 查询。这个我试过了
class CoopManager(models.Manager):
...
# Meant to look up coops case-insensitively by part of a type
def contains_type(self, types_arr):
queryset = Coop.objects.all()
for type in types_arr:
queryset = queryset.filter(type__name__icontains=type)
print(queryset.query)
return queryset
但是,这会产生一个将子句与在一起的查询。我如何执行上述操作,但使用 OR 而不是 AND 连接所有子句?
我正在使用 MySql 5.7,但我想知道一个独立于数据库的解决方案(如果存在的话)。
您可以创建一个构造此析取的 Q
对象:
from django.db.models import Q
filter = Q(
*[('type__name__icontains', type) for type in types_arr],
<b>_connector=Q.OR</b>
)
queryset = Coop.objects.filter(filter)
这里 filter
是一个 Q
对象,它是所有 type__name__icontains=type
过滤器的析取。