gpt4 book ai didi

javascript - 如何在 Django postgres 中使用 & 运算符组合 SearchQuery 来处理来自表单字段的不确定多个关键字

转载 作者:行者123 更新时间:2023-11-28 17:31:47 27 4
gpt4 key购买 nike

我有一个包含两个字段(标题、技能)的表单,其中关键字以逗号分隔。我们希望使用 SearchQuery'&' 运算符提供对所有技能的搜索。因此,如果我的 search_vectorSearchVector('job_title',) 并且假设用户正在寻找 Ex。 Java、Python、.net作为技能,我们可以编写我们的查询,例如..

PostedJobReq.objects.annotate(search=search_vector).filter(SearchQuery('java') & SearchQuery('python') & SearchQuery('.net')) 应该并且确实给了我们结果。

但我的情况是,我们得到了像 Ex 这样的关键字。来自 Formfield 的 Java、python、.net 等

  1. 我们不知道用户将搜索多少个关键字。
  2. 这些关键字是什么。

那么,当我什至不知道用户要搜索多少个关键字时,我该如何将多个 SearchQueries 连接在一起。我成功创建了所有 SearchQueries 的列表,但我无法使用代码中的 & 模块将它们连接起来。

View .py

enter image description here

complexadvsearch.html 这是我的模板的外观并包含搜索表单

enter image description here

Models.py 这就是我的模型的样子,简单的一些职位名称和其中使用的一些主要技能

enter image description here

最佳答案

您可以像这样组合 SearchQuery() 对象:

if filters:
my_filter = SearchQuery(filters.pop())

for f in filters:
my_filter |= SearchQuery(f)

就像 Q() 对象一样:

my_filter = Q()

for f in filters:
my_filter &= Q(something=f)

然后

Stuff.objects.filter(f)

这是 Django ORM 中非常酷的部分。

但是,如果所有条件都使用 &,则根本不需要使用 Q 对象。

就这样做:

filter_list = [SearchQuery(i) for i in filters]
Stuff.objects.filter(*filter_list)

关于javascript - 如何在 Django postgres 中使用 & 运算符组合 SearchQuery 来处理来自表单字段的不确定多个关键字,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50201833/

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