MongoDB
 sql >> Base de Dados >  >> NoSQL >> MongoDB

Mongo:Como agrupar por $ semana, mas retornar a data de início e a data de término de cada semana?


Embora seja factível, torna o código menos legível e mais complexo.

Vou reescrever o $group estágio para incluir year juntamente com weeks e adicione o $project estágio para formatar os dados conforme o requisito.
db.collection.aggregate([
  {
    "$group": {
      "_id": {
        "week": {
          "$week": {"$subtract": ["$at", 25200000]}  // <-- Changes timezone to -07:00
        },
        "year": {
          "$year": {"$subtract": ["$at", 25200000]}  // <-- Changes timezone to -07:00
        },
      },
      // <-- Add keys to be added in group along with its logics
      "averageValue": {
        "$avg": "$readings.level_1"
      }
    },
  },
  {
    "$project": {
      "_id": {
        "startDate": {
          "$dateToString": {
            "date": {
              "$dateFromParts": {
                "isoWeekYear": "$_id.year",
                "isoWeek": "$_id.week"
              }
            },
            "format": "%Y-%m-%d",
          },
        },
        "endDate": {
          "$dateToString": {
            "date": {
              "$add": [
                {
                  "$dateFromParts": {
                    "isoWeekYear": "$_id.year",
                    "isoWeek": "$_id.week"
                  }
                },
                518400000,
              ],
            },
            "format": "%Y-%m-%d",
          },
        },
      },
      // <-- Add remaining keys to be projected
      "averageValue": 1,
    },
  },
])

Deixe-me saber se você precisa de uma explicação de cada estágio e operador usado e por que eu o usei.

Execução de amostra do Mongo Playground