有没有办法连接q对象?

问题描述 投票:0回答:2

我一直在努力实现这一点。我正在尝试构建一个动态查询集,其中条件将基于用户输入。用户可以决定按名字或姓氏或两者的组合进行搜索。如果仅使用姓氏搜索,则不会将firstname查询添加到查询集中。我目前正在搜索输入的所有字段。

results = documents.objects.filter(
    Q(f_filer__filer_first_name__istartswith=request.GET.get('first_name', 
'')) & (f_filer__filer_last_name__istartswith=request.GET.get('last_name', 
'')) & 
Q(f_office__o_office_name__istartswith=request.GET.get('office_name', ''))
    & Q(f_doc_year__exact=request.GET.get('report_year', ''))
    & Q(f_report_id__exact=request.GET.get('filing_type', ''))       
    ).values('f_filer__filer_first_name',
          'f_filer__filer_last_name',
          'f_office__o_office_name',
          'f_date_received',
          'f_start_travel_date',
          'f_end_travel_date',
          'f_doc_year',
          'f_report__r_title')
django-models django-views django-orm qobject
2个回答
0
投票

你可以像这样连接filter

queryset = documents.objects.all()

first_name = request.GET.get('first_name')
last_name = request.GET.get('last_name')

if first_name:
    queryset = queryset.filter(first_name=first_name)
if last_name:
    queryset = queryset.filter(last_name=lastname)

我缩短了过滤器参数以简化示例


0
投票

你可以join Q objects using |,作为“或”:

first_name = request.GET.get('first_name', '')
last_name = request.GET.get('last_name', '')
Q(
    f_filer__filer_first_name__istartswith=first_name,
    f_filer__filer_last_name__istartswith=last_name
) |
Q(f_filer__filer_first_name__istartswith=first_name) |
Q(f_filer__filer_last_name__istartswith=last_name)

如果您的应用程序搜索量很大,则可能需要考虑设置正确的搜索后端。

你使用Postgres吗?如果是这样,使用Django的Postgres Full text search可能会简化操作并帮助使代码更易于维护。

如果您不使用Postgres,使用django-haystack设置搜索后端将为您提供类似的好处,并允许用户使用AutoQuery构建类似Google的查询。例如,使用-排除术语和精确短语的引号。

© www.soinside.com 2019 - 2024. All rights reserved.