Definição
Novidades na versão 5.0.
Trunca uma data.
$dateTrunc sintaxe:
{ $dateTrunc: { date: <Expression>, unit: <Expression>, binSize: <Expression>, timezone: <tzExpression>, startOfWeek: <Expression> } }
Campo | Obrigatório/Opcional | Descrição | ||||||
|---|---|---|---|---|---|---|---|---|
Obrigatório | ||||||||
Obrigatório | A unidade de tempo, especificada como uma expressão que deve ser resolvida para uma dessas strings:
Juntos, binSize e unit especificam o período de tempo usado no | |||||||
Opcional | O valor numérico de tempo, especificado como uma expressão que deve ser resolvida para um número positivo diferente de zero. O padrão é 1. Juntos, binSize e unit especificam o período de tempo usado no | |||||||
Opcional | O fuso horário para o cálculo, especificado Se nenhum fuso horário for fornecido, o cálculo será realizado em
| |||||||
Opcional | O início da semana. Usado quando unidade startOfWeek é uma expressão que deve ser resolvida para uma dessas strings que não diferenciam maiúsculas de minúsculas:
|
Comportamento
Retorna
nullse:qualquer um dos campos de entrada, exceto startOfWeek, está ausente ou definido como
null, ouse a unidade for
weeke startOfWeek estiver ausente ou definido comonull.
Usa o calendário gregoriano proléptico para datas anteriores ao ano 1583.
Contabiliza o horário de verão, mas não contabiliza os segundos bissextos.
binSize e unit campos
Juntos, binSize e unit especificam o período de tempo usado no cálculo $dateTrunc.
Por exemplo:
Se binSize for
1e unidade forhour, o período de tempo será de uma hora. Para a data2021-03-20T11:30:05Z,$dateTruncretorna2021-03-20T11:00:00Z.Se binSize for
2e unidade forhour, o período de tempo será de duas horas. Para a data2021-03-20T11:30:05Z,$dateTruncretorna2021-03-20T10:00:00Z.
Divide o tempo para o cálculo do
$dateTruncem períodos binSize na unidade de tempo especificada.Os períodos de tempo começam em uma data de referência, que é determinada por unidade. Se a unidade for:
Uma string diferente de
week,$dateTruncutiliza uma data de referência de2000-01-01T00:00:00.00Z. Por exemplo, se binSize for10e unidade foryear, os períodos de tempo de exemplo serão:2000-01-01T00:00:00.00Z2010-01-01T00:00:00.00Z2020-01-01T00:00:00.00Z
Igual a
week,$dateTruncusa uma data de referência que é definida como o primeiro dia da semana mais cedo que é maior ou igual a2000-01-01. O primeiro dia é definido usando startOfWeek (o padrão é domingo).
Retorna o limite inferior do período de tempo em que a data está. O limite é retornado como uma ISODate. Se o campo binSize estiver
1,$dateTruncdefine as partes menos significativas (conforme determinado por unidade) da ISODate retornada como0e mantém o restante da ISODate igual.
Se a unidade for:
year:$dateTruncretorna o ISODato para o início de janeiro de 1 para o ano em data.quarter::$dateTruncretorna o ISODato para o início do primeiro dia do trimestre do calendário em data.Os trimestres são:
De janeiro a março
De abril a junho
De julho a setembro
De outubro a dezembro
month:$dateTruncretorna o ISODate para o início do primeiro dia do mês em data.week:$dateTruncretorna a ISODate para o início do dia startOfWeek em data. O padrão de startOfWeek é domingo.day:$dateTruncretorna o ISODato para o início do dia em date (data).hour::$dateTruncretorna a ISODate para o início da hora em data.minute$dateTruncretorna a ISODate para o início do minuto em data.second::$dateTruncretorna o ISODato para o início do segundo em data.
unit e startOfWeek campos
Se a unidade for:
Uma string diferente de
week, startOfWeek é ignorada.Igual a
weeke startOfWeek é:Especificado:
$dateTruncusa startOfWeek como o primeiro dia da semana para o cálculo.Omitido:
$dateTruncutiliza Domingo como o início da semana para o cálculo.
Exemplos
Crie uma collection cakeSales que contenha vendas de bolo nos estados da Califórnia (CA) e de Washington (WA):
db.cakeSales.insertMany( [ { _id: 0, type: "chocolate", orderDate: new Date("2020-05-18T14:10:30Z"), state: "CA", price: 13, quantity: 120 }, { _id: 1, type: "chocolate", orderDate: new Date("2021-03-20T11:30:05Z"), state: "WA", price: 14, quantity: 140 }, { _id: 2, type: "vanilla", orderDate: new Date("2021-01-11T06:31:15Z"), state: "CA", price: 12, quantity: 145 }, { _id: 3, type: "vanilla", orderDate: new Date("2020-02-08T13:13:23Z"), state: "WA", price: 13, quantity: 104 }, { _id: 4, type: "strawberry", orderDate: new Date("2019-05-18T16:09:01Z"), state: "CA", price: 41, quantity: 162 }, { _id: 5, type: "strawberry", orderDate: new Date("2019-01-08T06:12:03Z"), state: "WA", price: 43, quantity: 134 } ] )
A coleção cakeSales é utilizada nos seguintes exemplos.
Truncar datas de pedido em um $project estágio de pipeline
Este exemplo usa $dateTrunc em um estágio $project para truncar os valores de orderDate de vendas de bolo para duas semanas:
db.cakeSales.aggregate( [ { $project: { _id: 1, orderDate: 1, truncatedOrderDate: { $dateTrunc: { date: "$orderDate", unit: "week", binSize: 2, timezone: "America/Los_Angeles", startOfWeek: "Monday" } } } } ] )
No exemplo:
$projectinclui os campos_id,orderDateetruncatedOrderDatena saída.$dateTrunctrunca o campoorderDatepara um2weekunidade períodoAmerica/Los_Angelesde binSize fuso horário com startOfWeek definido comoMonday.
Neste exemplo de saída, o orderDate truncado é mostrado no campo truncatedOrderDate:
[ { _id: 0, orderDate: ISODate("2020-05-18T14:10:30.000Z"), truncatedOrderDate: ISODate("2020-05-11T07:00:00.000Z") }, { _id: 1, orderDate: ISODate("2021-03-20T11:30:05.000Z"), truncatedOrderDate: ISODate("2021-03-15T07:00:00.000Z") }, { _id: 2, orderDate: ISODate("2021-01-11T06:31:15.000Z"), truncatedOrderDate: ISODate("2021-01-04T08:00:00.000Z") }, { _id: 3, orderDate: ISODate("2020-02-08T13:13:23.000Z"), truncatedOrderDate: ISODate("2020-02-03T08:00:00.000Z") }, { _id: 4, orderDate: ISODate("2019-05-18T16:09:01.000Z"), truncatedOrderDate: ISODate("2019-05-13T07:00:00.000Z") }, { _id: 5, orderDate: ISODate("2019-01-08T06:12:03.000Z"), truncatedOrderDate: ISODate("2019-01-07T08:00:00.000Z") } ]
Truncar datas de pedidos e obter soma de quantidade em um $group estágio de pipeline
Este exemplo usa $dateTrunc em um estágio $group para truncar os valores orderDate de vendas do bolo para seis meses e retornar a soma dos valores quantity:
db.cakeSales.aggregate( [ { $group: { _id: { truncatedOrderDate: { $dateTrunc: { date: "$orderDate", unit: "month", binSize: 6 } } }, sumQuantity: { $sum: "$quantity" } } } ] )
No exemplo:
$grouptem o campo_idconfigurado para o campotruncatedOrderDatepara agrupar os documentoscakeSalese retorna a soma dos valoresquantitypara cada grupo utilizando$sum.$dateTrunctrunca o campoorderDateem um período de6binSizemonthunit.
Neste exemplo de saída, o orderDate truncado é mostrado no campo truncatedOrderDate e a soma quantity é mostrada no campo sumQuantity :
[ { _id: { truncatedOrderDate: ISODate("2020-01-01T00:00:00.000Z") }, sumQuantity: 224 }, { _id: { truncatedOrderDate: ISODate("2021-01-01T00:00:00.000Z") }, sumQuantity: 285 }, { _id: { truncatedOrderDate: ISODate("2019-01-01T00:00:00.000Z") }, sumQuantity: 296 } ]