$isoWeek (agregação)
Nesta página
Definição
$isoWeek
Retorna o número da semana no formato ISO 8601, que varia de
1
a53
. Os números da semana começam em1
com a semana (de segunda a domingo) que contém a primeira quinta-feira do ano.A expressão
$isoWeek
tem a seguinte sintaxe de expressão do operador:{ $isoWeek: <dateExpression> } O argumento pode ser:
Uma expressão que produza uma Data, um Timestamp ou um ObjectID.
Um documento com este formato:
{ date: <dateExpression>, timezone: <tzExpression> } CampoDescriçãodate
timezone
Optional.
O fuso horário do resultado da operação.<tzExpression>
deve ser uma expressão válida que resolva para uma string formatada como um identificador de fuso horário Olson ou um UTC Offset. Se nenhumtimezone
for fornecido, o resultado será exibido emUTC
.FormatarExemplosOlson Timezone Identifier
"America/New_York" "Europe/London" "GMT" UTC Offset
+/-[hh]:[mm], e.g. "+04:45" +/-[hh][mm], e.g. "-0530" +/-[hh], e.g. "+03"
Comportamento
Exemplo | Resultado | ||||
---|---|---|---|---|---|
| 1 | ||||
| 53 | ||||
| 32 | ||||
| 45 | ||||
| 44 | ||||
| error | ||||
| error | ||||
| error |
Observação
$isoWeek não pode aceitar uma string como argumento.
Exemplo
Uma coleção chamada deliveries
contém os seguintes documentos:
db.deliveries.insertMany( [ { _id: 1, date: ISODate("2006-10-24T00:00:00Z"), city: "Boston" }, { _id: 2, date: ISODate("2011-08-18T00:00:00Z"), city: "Detroit" } ] )
A seguinte operação retorna o número da semana para cada campo date
.
db.deliveries.aggregate( [ { $project: { _id: 0, city: "$city", weekNumber: { $isoWeek: "$date" } } } ] )
A operação retorna os seguintes resultados:
[ { city: "Boston", weekNumber: 43 }, { city: "Detroit", weekNumber: 33 } ]