In MongoDB der $second
Der Aggregations-Pipeline-Operator gibt den zweiten Teil eines Datums als Zahl zwischen 0
zurück und 59
. Der Wert kann auch 60
sein um gegebenenfalls Schaltsekunden zu berücksichtigen.
Sie können optional eine Zeitzone angeben, die für das Ergebnis verwendet werden soll.
Die $second
-Operator akzeptiert entweder ein Datum (entweder als Date, Timestamp oder ObjectId) oder ein Dokument, das das zu verwendende Datum und die zu verwendende Zeitzone angibt.
Beispiel
Angenommen, wir haben eine Sammlung namens pets
mit folgendem Dokument:
{ "_id" : ObjectId("600631c7c8eb4369cf6ad9c8"), "name" : "Fetch", "born" : ISODate("2020-12-31T23:30:15.123Z") }
Wir können den folgenden Code ausführen, um den zweiten Teil aus born
zu extrahieren Feld in diesem Dokument.
db.pets.aggregate(
[
{
$project:
{
_id: 0,
birthSecond: { $second: "$born" }
}
}
]
)
Ergebnis:
{ "birthSecond" : 15 }
Hier habe ich birthSecond
verwendet als zurückzugebender Feldname, aber das hätte alles sein können (wie secondsAtBirth
, seconds
, etc).
Die _id
Das Feld wird standardmäßig zurückgegeben, wenn Projektionen in MongoDB verwendet werden, aber in diesem Beispiel habe ich die _id
explizit ausgeblendet Feld mit _id: 0
.
Geben Sie eine Zeitzone an
Sie können eine Zeitzone angeben, die für die Ausgabe von $second
verwendet werden soll Betreiber.
Wenn Sie dies tun, wird das Argument an $second
übergeben muss folgende Form haben:
{ date: <dateExpression>, timezone: <tzExpression> }
Wobei <dateExpression>
ist das zu verwendende Datum und <tzExpression>
ist die zu verwendende Zeitzone.
Die Zeitzone kann entweder mit der Olson-Zeitzonenkennung (z. B. "Europe/London"
, "GMT"
) oder den UTC-Offset (z. B. "+02:30"
). , "-1030"
).
Olson-Zeitzonenkennung
Hier ist ein Beispiel, das die Sekunden in zwei verschiedenen Zeitzonen ausgibt, die jeweils die Olson-Zeitzonen-IDs verwenden:
db.pets.aggregate(
[
{
$project: {
_id: 0,
kabul: {
$second: { date: "$born", timezone: "Asia/Kabul" }
},
brisbane: {
$second: { date: "$born", timezone: "Australia/Brisbane" }
}
}
}
]
)
Ergebnis:
{ "kabul" : 15, "brisbane" : 15 }
Da sich die Zeitzonenänderung nicht auf den Sekundenteil auswirkt, ist das Ergebnis dasselbe.
UTC-Offset
In diesem Beispiel verwenden wir den UTC-Offset.
db.pets.aggregate(
[
{
$project: {
_id: 0,
"utcOffset+04:30": {
$second: { date: "$born", timezone: "+04:30" }
},
"utcOffset+05:45": {
$second: { date: "$born", timezone: "+05:45" }
}
}
}
]
)
Ergebnis:
{ "utcOffset+04:30" : 15, "utcOffset+05:45" : 15 }
Gib die Sekunden von einer ObjectId zurück
Sie können $second
verwenden um den Sekundenteil einer ObjectId zurückzugeben.
ObjectId-Werte sind 12-Byte-Hexadezimalwerte, die aus Folgendem bestehen:
- Ein 4-Byte-Zeitstempelwert, der die Erstellung der ObjectId darstellt, gemessen in Sekunden seit der Unix-Epoche.
- Ein 5 Byte ist ein Zufallswert
- Ein inkrementierender 3-Byte-Zähler, initialisiert auf einen zufälligen Wert.
Zusammenfassend sieht unser Dokument folgendermaßen aus:
{ "_id" : ObjectId("600631c7c8eb4369cf6ad9c8"), "name" : "Fetch", "born" : ISODate("2020-12-31T23:30:15.123Z") }
Dieses Dokument enthält eine ObjectId. Wir können daher $second
verwenden um die Sekunde zurückzugeben, in der unser Dokument erstellt wurde (oder genauer gesagt, wenn die _id
der ObjectId-Wert des Felds wurde erstellt).
Beispiel:
db.pets.aggregate(
[
{
$project:
{
"timeStamp": { $toDate: "$_id"},
"second": { $second: "$_id" }
}
}
]
).pretty()
Ergebnis:
{ "_id" : ObjectId("600631c7c8eb4369cf6ad9c8"), "timeStamp" : ISODate("2021-01-19T01:11:35Z"), "second" : 35 }
Wir können sehen, dass das Dokument in der 35. Sekunde (der 11. Minute der 1. Stunde des Tages) erstellt wurde.
In diesem Fall habe ich auch den $toDate
verwendet Aggregations-Pipeline-Operator, um den Zeitstempelteil der ObjectId zurückzugeben.