我如何用任意数量的OR子句构成Django查询?

问题描述 投票:1回答:1

我正在将Django 2.0与Python 3.7结合使用。我想编写一个查询,如果字段包含数组中的至少一个字符串,则返回结果,因此我想设置一个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,但如果有的话,我想知道一个独立于数据库的解决方案。

mysql sql django python-3.x contains
1个回答
1
投票

您可以创建构造此析取项的Q对象:

from django.db.models import Q

filter = Q(
    *[('type__name__icontains', type) for type in types_arr],
    _connector=Q.OR
)
queryset = Coop.objects.filter(filter)

这里filter是一个Q对象,它是所有type__name__icontains=type过滤器的析取。

© www.soinside.com 2019 - 2024. All rights reserved.