我必须运行复杂聚合,其中一个步骤是计算sold_qty字段的总和,然后我需要将此总和与非聚合字段all_qty相减。我的数据如下:计算字段和聚合字段之间的差异
{item_id: XXX, sold_qty: 1, all_qty: 20, price: 100 }
{item_id: XXX, sold_qty: 3, all_qty: 20, price: 100 }
{item_id: YYY, sold_qty: 1, all_qty: 20, price: 80 }
这些是来自要约的交易。 all_qty和price字段是多余的 - 表示来自其他结构的单个值 - 报价并且仅在单个报价(由item_id标识)的所有交易中重复。
在SQL中的条款我需要的是:
SELECT (all_qty - sum(sold_qty)) * price GROUP BY item_id
我所做的是聚集
'{
"query": {"term": {"seller": 9059247}},
"size": 0,
"aggs": {
"group_by_offer": {
"terms": { "field": "item_id", size: 0},
"aggs": { "sold_sum": {"sum": {"field": "sold_qty"}}}
}
}
}'
但我不知道下一步该怎么做,以实现我的目标。
你有哪个版本的ES的? – Val