MongoDB の出力フォーマットの集計関数はどの程度柔軟ですか?
データ形式:
{
"_id" : ObjectId("506ddd1900a47d802702a904"),
"port_name" : "CL1-A",
"metric" : "772.0",
"port_number" : "0",
"datetime" : ISODate("2012-10-03T14:03:00Z"),
"array_serial" : "12345"
}
現在、この集計関数を使用して、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}}}
これは素晴らしく、非常に高速ですが、日時/メトリックごとに1つの配列になるように出力をフォーマットする方法はありますか? このような:
[
{
"_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]
]
}
]
これは、チャートコードが期待するフォーマットであるため、フロントエンドを大幅に簡素化します。