![](/img/trans.png)
[英]How to add an OR filter around a nested query with elasticsearch-dsl
[英]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.