我正在将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,但是我想知道一个独立于数据库的解决方案,如果存在的话。
问题来源:stackoverflow
您可以创建一个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过滤器的析取。
回答来源:stackoverflow
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。