gpt4 book ai didi

Elasticsearch 聚合查询

转载 作者:行者123 更新时间:2023-12-02 22:38:18 25 4
gpt4 key购买 nike

我正在做一个关于 cooking 食谱的项目。我安装了 Elasticsearch 1.5.2,并在超市的许多索引中添加了很多蔬菜或肉类等产品。在我开始聚合查询之前一切都很好。例如:要制作土 bean 泥,我需要土 bean 、 bean 类、鹰嘴 bean 、西兰花、牛奶、胡椒粉、盐。我已经储存了所有这些产品。我需要进行一次查询以在所有索引中搜索该产品中最便宜的。我尝试了很多查询,但没有找到我需要的。

这是示例,所有这些查询都有效,但我需要在一个查询中得到它们的结果:

 POST /_search
{
"query": {
"query_string": {
"query": "pommes de terre",
"fields": [
"titre"
]
}
},
"sort" : [
{"prix en €/kg" : {"order" : "asc"}}
]
}

POST /_search
{
"query": {
"query_string": {
"query": "haricots",
"fields": [
"titre"
]
}
},
"sort" : [
{"prix en €/kg" : {"order" : "asc"}}
]
}

POST /_search
{
"query": {
"query_string": {
"query": "pois chiche",
"fields": [
"titre"
]
}
},
"sort" : [
{"prix en €/kg" : {"order" : "asc"}}
]
}

POST /_search
{
"query": {
"query_string": {
"query": "brocoli",
"fields": [
"titre"
]
}
},
"sort" : [
{"prix en €/kg" : {"order" : "asc"}}
]
}

POST /_search
{
"query": {
"query_string": {
"query": "lait",
"fields": [
"tags"
]
}
},
"sort" : [
{"prix en €/L" : {"order" : "asc"}}
]
}

POST /_search
{
"query": {
"query_string": {
"query": "poivre",
"fields": [
"tags"
]
}
},
"sort" : [
{"prix en €/kg" : {"order" : "asc"}}
]
}

POST /_search
{
"query": {
"query_string": {
"query": "sel",
"fields": [
"tags"
]
}
},
"sort" : [
{"prix en €/kg" : {"order" : "asc"}}
]
}

我只想有一个查询来获取所有这些查询的结果,我只想要最便宜的查询,而不是所有列表。

最佳答案

你可以定义一个 filter aggregation对于您查询中的每个产品

{
"aggs" : {
"sel" : {
"filter" : {
"query_string": {
"query": "sel",
"fields": [
"titre"
]
}
}
},
"haricots" : {
"filter" : {
"query_string": {
"query": "haricots",
"fields": [
"titre"
]
}
}
}
}
}

请注意,在 ES<2,您 probably will have to wrap your filterquery目的:
{
"aggs" : {
"sel" : {
"filter" : {
"query": {
"query_string": {
"query": "sel",
"fields": [
"titre"
]
}
}
}
},
"haricots" : {
"filter" : {
"query": {
"query_string": {
"query": "haricots",
"fields": [
"titre"
]
}
}
}
}
}
}

每个聚合都会构建一个与您的过滤器相对应的存储桶。然后添加 top hits sub aggregation到这些桶中的每一个,以获得最低的价格。例如,使用 sel 存储桶:
{
"aggs" : {
"sel" : {
"filter" : {
"query_string": {
"query": "sel",
"fields": [
"titre"
]
}
},
"aggs" : {
"minprice": {
"top_hits": {
"sort": [
{
"prix en €/kg": {
"order": "asc"
}
}
],
"size" : 1
}
}
}
}
}
}

还有一个更完整的例子,包括 sel、西兰花和扁 bean
{
"aggs" : {
"sel" : {
"filter" : {
"query_string": {
"query": "sel",
"fields": [
"titre"
]
}
},
"aggs" : {
"minprice": {
"top_hits": {
"sort": [
{
"prix en €/kg": {
"order": "asc"
}
}
],
"size" : 1
}
}
}
},
"haricots" : {
"filter" : {
"query_string": {
"query": "haricots",
"fields": [
"titre"
]
}
},
"aggs" : {
"minprice": {
"top_hits": {
"sort": [
{
"prix en €/kg": {
"order": "asc"
}
}
],
"size" : 1
}
}
}
},
"brocoli" : {
"filter" : {
"query_string": {
"query": "brocoli",
"fields": [
"titre"
]
}
},
"aggs" : {
"minprice": {
"top_hits": {
"sort": [
{
"prix en €/kg": {
"order": "asc"
}
}
],
"size" : 1
}
}
}
}
}
}

你的结果看起来像
{
"aggregations" : {
"sel" : {
"doc_count" : 2,
"minprice" : {
"hits" : {
"total" : 2,
"max_score" : null,
"hits" : [
{
"_index" : "test",
"_type" : "product",
"_id" : "1",
"_score" : null,
"_source" : {
"id" : 1,
"titre" : "sel 1",
"prix en €/kg" : 1
},
"sort" : [
1.0
]
}
]
}
}
},
"haricots" : {
"doc_count" : 1,
"minprice" : {
"hits" : {
"total" : 1,
"max_score" : null,
"hits" : [
{
"_index" : "test",
"_type" : "product",
"_id" : "3",
"_score" : null,
"_source" : {
"id" : 3,
"titre" : "haricots",
"prix en €/kg" : 3
},
"sort" : [
3.0
]
}
]
}
}
}
}
}

关于Elasticsearch 聚合查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41980153/

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