Django SQL OR via filter()&问():动态?

时间:2010-11-10 17:46:50

标签: django django-queryset django-q

我正在我的Django网站上实现一个简单的LIKE搜索,我目前使用的是以下代码:

from django.db.models import Q
posts = Post.objects.filter(Q(title__icontains=query)|Q(content__icontains=query))

query是一个字符串。这导致LIKE SQL语句并且工作正常。现在我还想将搜索查询拆分为术语或单词:

words = query.split(' ')

所以words现在包含一个单词列表,我想要实现一个类似于的语句:

SELECT ... FROM foo WHERE `title` ILIKE '%word1%' OR `title` ILIKE '%word2%'
  OR `content` ILIKE '%word1%' OR `content` ILIKE '%word2%'

如果有两个以上的单词,我希望语句增长,按每个单词列出所有条目。

有什么想法吗?谢谢!

1 个答案:

答案 0 :(得分:11)

reduce(operator.or_, sequence_of_Q_objects)