$isoWeekYear (agregação)
Nesta página
Definição
$isoWeekYear
Novidade na versão 3.4.
Retorna o número do ano no formato ISO 8601. O ano começa com a segunda-feira da semana 1 e termina com o domingo da última semana.
A expressão
$isoWeekYear
tem a seguinte sintaxe de expressão do operador:{ $isoWeekYear: <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 | ||||
---|---|---|---|---|---|
| 2015 | ||||
| 2003 | ||||
| 2017 | ||||
| 2016 | ||||
| 2024 | ||||
| error | ||||
| error | ||||
| error |
Observação
$isoWeekYear não pode usar uma string como argumento.
Exemplo
Uma coleção chamada anniversaries
contém os seguintes documentos:
{ "_id" : 1, "date" : ISODate("2016-01-01T00:00:00Z") } { "_id" : 2, "date" : ISODate("2016-01-04T00:00:00Z") } { "_id" : 3, "date" : ISODate("2015-01-01T00:00:00Z") } { "_id" : 4, "date" : ISODate("2014-04-21T00:00:00Z") }
A operação a seguir retorna o número do ano no formato ISO 8601 para cada campo date
.
db.anniversaries.aggregate( [ { $project: { yearNumber: { $isoWeekYear: "$date" } } } ] )
A operação retorna os seguintes resultados:
{ "_id" : 1, "yearNumber" : 2015 } { "_id" : 2, "yearNumber" : 2016 } { "_id" : 3, "yearNumber" : 2015 } { "_id" : 4, "yearNumber" : 2014 }