我正在使用operator.or_并将Query()对象传递给它。 Query()对象包含3个查询,即
当我获得输出时,结果顺序不正确?像我想先按名称,然后描述,然后标题?
这是示例代码
def search(self, search_terms, filters, category=False, vendor=False):
terms = [term.strip() for term in search_terms.split()]
q_objects = []
if terms:
for term in terms:
q_objects.append(Q(name__icontains=search_terms))
q_objects.append(Q(description__icontains=search_terms))
q_objects.append(Q(title__icontains=search_terms))
qs = self.get_query_set()
if len(q_objects) > 1:
return qs.filter(reduce(operator.or_, q_objects))
else:
return qs
那么,有人可以帮助它先按名称搜索顺序,然后按描述搜索,然后标题吗?
提前致谢 !
最佳答案
排序是由 QuerySet.order_by
完成的,因此除了过滤查询集外,还要执行以下操作:
qs = qs.order_by('name', 'description', 'title')
关于django - Order_By:Django Q对象顺序?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/33000473/