gpt4 book ai didi

django rest framework 搜索过滤所有字段

转载 作者:行者123 更新时间:2023-12-04 00:25:40 35 4
gpt4 key购买 nike

我有一个基本模型 View 集,可以处理订单、分页和搜索功能。当我有适当的过滤器后端时,我可以设置 ordering_fields、search_fields 但我的问题是: 就像我可以设置 ordering_fields = '__all__' 是不是可以为所有人设置 search_fields?

我一直在寻找深层过滤机制并来到这里:

def filter_queryset(self, request, queryset, view):
search_fields = getattr(view, 'search_fields', None)

if not search_fields:
return queryset

orm_lookups = [self.construct_search(six.text_type(search_field))
for search_field in search_fields]

for search_term in self.get_search_terms(request):
or_queries = [models.Q(**{orm_lookup: search_term})
for orm_lookup in orm_lookups]
queryset = queryset.filter(reduce(operator.or_, or_queries))

return queryset

如果设置了 drf search_fields='__all__',则 drf 无法生成 search_fields有没有其他方法可以提供按所有功能进行搜索?

最佳答案

不可能,而且这也不是一个好主意..

一个原因是因为可以有不同类型的搜索查询(__istartswith__iexact 等),您可以为每个字段名称设置它们。

您还可以有不同的字段类型,这些字段类型不一定支持基于文本的搜索。

更重要的是 - 它会导致查询速度变慢,同时您不断向模型中添加新字段。明确说明总是更好,这样您就知道实际搜索了哪些字段。

如果您的搜索功能依赖于多个字段,也许您应该考虑 haystack或寻找任何其他专用搜索引擎。

关于django rest framework 搜索过滤所有字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30732042/

35 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com