日付オブジェクトを UTC で保存する MongoDB があります。さて、別のタイムゾーン(CET)で年月日ごとに集計を行いたいと思います。
これを行うと、UTC で正常に動作します。
BasicDBObject group_id = new BasicDBObject("_id", new BasicDBObject("year", new BasicDBObject("$year", "$tDate")).
append("month", new BasicDBObject("$month", "$tDate")).
append("day", new BasicDBObject("$dayOfMonth", "$tDate")).
append("customer", "$customer"));
BasicDBObject groupFields = group_id.
append("eventCnt", new BasicDBObject("$sum", "$eventCnt"));
BasicDBObject group = new BasicDBObject("$group", groupFields);
または、コマンドラインを使用する場合 (テストされていません。私は Java バージョンのみをテストしました):
{
$group: {
_id: {
"year": {
"$year", "$tDate"
},
"month": {
"$month", "$tDate"
},
"day": {
"$dayOfMonth", "$tDate"
},
"customer": "$customer"
},
"eventCount": {
"$sum": "$eventCount"
}
}
}
集計フレームワーク内でこれらの日付を CET に変換するにはどうすればよいですか?
たとえば、「2013-09-16 23:45:00 UTC」は「2013-09-17 00:45:00 CET」で、これは別の日です。