Я получаю неожиданный результат и немного растерялся.
Я добавил эти документы :
POST es_test/_doc/_bulk?pretty
{ "index": {}}
{ "firstname": "John", "lastname": "Doe", "age": 22, "birthdate": "1980-01-20T12:30:00Z" }
{ "index": {}}
{ "firstname": "May", "lastname": "Greenwood", "age": 19, "birthdate": "1980-01-20T12:30:00Z" }
{ "index": {}}
{ "firstname": "Marry", "lastname": "Hilake", "age": 32, "birthdate": "1970-01-20T12:30:00Z" }
{ "index": {}}
{ "firstname": "Mister", "lastname": "X", "age": 20, "birthdate": "1990-11-23T12:30:00Z" }
все хорошо , когда я запрашиваю их следующим образом:
GET es_test/_doc/_search
Проблема возникает , когда я добавляю безболезненный скрипт :
GET es_test/_doc/_search
{
"size": 0,
"aggs": {
"user": {
"scripted_metric": {
"init_script" : "params._agg.transactions = []",
"map_script" : "params._agg.transactions.add(params._source)"
}
}
}
}
Вывод выглядит следующим образом:
{
"took": 0,
"timed_out": false,
"_shards": {
"total": 5,
"successful": 5,
"skipped": 0,
"failed": 0
},
"hits": {
"total": 4,
"max_score": 0,
"hits": []
},
"aggregations": {
"user": {
"value": [
{
"transactions": [
{
"firstname": "John",
"birthdate": "1980-01-20T12:30:00Z",
"age": 22,
"lastname": "Doe"
},
{
"firstname": "John",
"birthdate": "1980-01-20T12:30:00Z",
"age": 22,
"lastname": "Doe"
}
]
},
{
"transactions": []
},
{
"transactions": [
{
"firstname": "May",
"birthdate": "1980-01-20T12:30:00Z",
"age": 19,
"lastname": "Greenwood"
}
]
},
{
"transactions": []
},
{
"transactions": [
{
"firstname": "Marry",
"birthdate": "1970-01-20T12:30:00Z",
"age": 32,
"lastname": "Hilake"
}
]
}
]
}
}
}
Первый массив transactions
включает в себя два раза Джона, второй пустой, затем идет май,снова пусто и, наконец, жениться. Я понятия не имею, почему это так странно .
Желаемый вывод будет один массив, который включает всех пользователей (Джон, май, женитьсяМистер).
Я ценю вашу помощь, спасибо! Игра