Las traducciones son generadas a través de traducción automática. En caso de conflicto entre la traducción y la version original de inglés, prevalecerá la version en inglés.
$hour
El $hour operador extrae el componente de hora de un campo de fecha o marca de hora.
Parámetros
-
dateExpression: la fecha a la que se aplica el operador. Esto debe resolverse en una fecha BSON válida (por ejemplo, un campo como $createdAt o una fecha literal).
Un parámetro también se puede especificar como un documento con el siguiente formato:
{fecha:<dateExpression>, zona horaria:} <timezoneExpression>
Esto permite aplicar operaciones de fecha que tengan en cuenta la zona horaria.
- `<tzExpression>`: (optional) The timezone of the operation result. It must be a valid expression that resolves to a string formatted as either an Olson Timezone Identifier or a UTC Offset. If no timezone is provided, the result is in UTC.
Ejemplo (MongoDB Shell)
El siguiente ejemplo muestra cómo utilizar el $hour operador para extraer el componente de hora de un campo de fecha y agrupar los datos en consecuencia.
Cree documentos de muestra
db.events.insertMany([ { timestamp: new Date("2023-04-01T10:30:00Z") }, { timestamp: new Date("2023-04-01T12:45:00Z") }, { timestamp: new Date("2023-04-02T08:15:00Z") }, { timestamp: new Date("2023-04-02T16:20:00Z") }, { timestamp: new Date("2023-04-03T23:59:00Z") } ]);
Ejemplo de consulta
db.events.aggregate([ { $project: { hour: { $hour: "$timestamp" } } }, { $group: { _id: "$hour", count: { $sum: 1 } } }, { $sort: { _id: 1 } } ]);
Salida
[
{ "_id": 8, "count": 1 },
{ "_id": 10, "count": 1 },
{ "_id": 12, "count": 1 },
{ "_id": 16, "count": 1 },
{ "_id": 23, "count": 1 }
]
Esta consulta agrupa los eventos por el componente horario del timestamp campo y cuenta el número de eventos de cada hora.
Ejemplos de código
Para ver un ejemplo de código para usar el $hour comando, elija la pestaña correspondiente al idioma que desee usar: