首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在django-filter中使用OR子句

在django-filter中使用OR子句
EN

Stack Overflow用户
提问于 2022-08-27 05:55:32
回答 1查看 41关注 0票数 1

我正在使用django-filter + django rest框架。我想搜索一个带有OR子句的术语。我有一个过滤器:

代码语言:javascript
复制
class ItemFilter(filters.FilterSet):
    name = filters.CharFilter(field_name="name")
    barcode = filters.CharFilter(field_name="barcode")

    class Meta:
        model = Item
        fields = ['name', 'barcode']

当我发送类似于https://url?barcode=q&name=q django-filter搜索的查询参数时:

代码语言:javascript
复制
SELECT * FROM item where name = 'q' AND barcode = 'q'

如何配置为搜索?:

代码语言:javascript
复制
SELECT * FROM item where name = 'q' OR barcode = 'q'
EN

回答 1

Stack Overflow用户

发布于 2022-08-27 07:07:04

其中一个选项是在视图中使用SearchFilter对多个字段进行筛选:

代码语言:javascript
复制
from rest_framework import filters

class YourView(generics.ListAPIView):
    queryset = Item.objects.all()
    serializer_class = ...
    filter_backends = [filters.SearchFilter]
    search_fields = ['name', 'barcode']

然后在url查询参数中使用search关键字:https://url?search=q

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73508705

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档