Tatsächlich ist es möglich, der Trick besteht darin, Ihre Millisekundenzeit zu einem 0-Millisekunden-Date()-Objekt hinzuzufügen, indem Sie eine ähnliche Syntax verwenden wie:
dt : {$add: [new Date(0), "$time"]}
Ich habe Ihre Aggregation von oben geändert, um das Ergebnis zu erzeugen:
db.events.aggregate(
{
$project : {
_id : "$_id",
dt : {$add: [new Date(0), "$time"]}
}
},
{
$project : {
_id : "$_id",
date : {
hour : {$hour : "$dt"}
}
}
}
);
Das Ergebnis ist (mit einer Eingabe Ihrer Beispieldaten):
{
"result": [
{
"_id": ObjectId("532828ac338ed9c33aa8eca7"),
"date": {
"hour": 11
}
}
],
"ok": 1
}