从上周开始,我正在使用AWS上的Elastic Search Service。我当前的Elasticseach版本是6.XX和Kibana 6.XX,现在我对在Kibana Client上运行的查询格式有点灵活性。但是我的问题是我无法将查询转换为将在Browser URL / Postman上运行的URI格式。例如:如何将其转换为URI搜索格式?
GET my_index/_search
{
"query": {
"geo_bounding_box": {
"location": {
"top_left": {
"lat": 42,
"lon": -72
},
"bottom_right": {
"lat": 40,
"lon": -74
}
}
}
}
}
我在这里看到关于URI格式搜索的文档具有不同的PARAMS像q,DF等:https://www.elastic.co/guide/en/elasticsearch/reference/6.0/search-uri-request.html但不能将上述查询字符串转换为URI搜索格式。实际上,我对支持q,fq,排序,开始,行,boost,facet,group等的SOLR查询格式非常灵活。因此,据我所知,弹性搜索也使用了Lucene Indexing,所以我的基本问题是
1.如何将上述ES查询字符串转换为URI搜索格式?
2.如何轻松将SOLR查询转换为ES格式?
如果您帮助我将上述查询字符串转换为URI搜索格式,那么将现有的复杂SOLR查询转换为ES查询将大有帮助。
注意:我可以使用?q =参数转换基本的CRUD操作,但是很难隐蔽其他方面,例如facet,boost,group等。
编辑:实际上我想说这个查询参数返回相同的文档数量。两者均来自solr和es-在这里,我仅将_source用于ES,因为我们将fl用于SOLR。否则一切都一样
https:// my_host / rental_properties / _search?_source = id,代码:feed_provider_id,feed_provider_id,feed,property_name,pax:入住率,卧室数量,最小住宿,星级,night_rate_min,currency&q = feed:11 AND-预定日期:[2018-02- 23T00:00:00Z TO 2018-02-26T00:00:00Z] AND min_stay:[* TO 3] AND occupancy:[3 TO *] AND -latlon:0.001,0.001
从Val的答案中,我知道1我可以轻松地将相同的查询字符串用于URI搜索。2。但是,如何将SOLR查询轻松转换为ES格式?
请注意,通过将DSL查询放入source
query参数中,始终可以使用与URI搜索完全相同的DSL查询。您还需要添加source_content_type=application/json
参数。因此,您的查询将如下所示:
GET my_index/_search?source_content_type=application/json&source={"query":{"geo_bounding_box":{"location":{"top_left":{"lat":42,"lon":-72},"bottom_right":{"lat":40,"lon":-74}}}}}
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句