Насколько гибкой является агрегатная функция для форматирования вывода в MongoDB?
Формат данных:
{
"_id" : ObjectId("506ddd1900a47d802702a904"),
"port_name" : "CL1-A",
"metric" : "772.0",
"port_number" : "0",
"datetime" : ISODate("2012-10-03T14:03:00Z"),
"array_serial" : "12345"
}
Сейчас я использую эту функцию aggregate для возврата массива DateTime, массива показателей и числа:
{$match : { 'array_serial' : array,
'port_name' : { $in : ports},
'datetime' : { $gte : from, $lte : to}
}
},
{$project : { port_name : 1, metric : 1, datetime: 1}},
{$group : { _id : "$port_name",
datetime : { $push : "$datetime"},
metric : { $push : "$metric"},
count : { $sum : 1}}}
Что хорошо, и очень быстро, но есть ли способ форматировать вывод, чтобы там был один массив в datetime/metric? Вот так:
[
{
"_id" : "portname",
"data" : [
["2012-10-01T00:00:00.000Z", 1421.01],
["2012-10-01T00:01:00.000Z", 1361.01],
["2012-10-01T00:02:00.000Z", 1221.01]
]
}
]
Это значительно упростит интерфейс, так как формат, который ожидает код диаграммы.