繁体   English   中英

Elasticsearch - 如何将范围过滤器添加到搜索查询

[英]Elasticsearch - How to add range filter to search query

我使用 elasticsearch -dsl来查询 python 中的 Elasticsearch。
我想搜索带有text字段的文档并获取所有created字段小于datetime.now()的文档。
我执行以下查询,但 elasticsearch 引发错误。

q = "some word"
es.search(
        index="comment",
        body={
            "query": {
                "query_string": {
                    "query": f"*{q}*" ,
                    "default_field": "text"
                },
                "range": {"created": {"lt": datetime.now()}}
            },
            "fields": ["id"],
            "size": 10
        },
    )

以下是 elasticsearch 错误:

elasticsearch.exceptions.RequestError: RequestError(400, 'parsing_exception', '[query_string] malformed query, expected [END_OBJECT] but found [FIELD_NAME]')

注意:当我评论"range": {"created": {"lt": datetime.now()}}时,查询将正常工作(但不应用日期时间过滤器)。

您不能像这样组合几种类型的查询,请使用bool

{
  "query": {
    "bool": {
      "must": [{"query_string": {"query": f"*{q}*" , "default_field": "text"}}],
      "filter": [{"range": {"created": {"lt": datetime.now()}}}]}
    }
  }
}

请注意,全文query_string子句进入must部分并被评分,而range过滤器进入filter并且 ES 不计算这些分数。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM