Como calcular a soma dos campos dos documentos da coleção mongodb usando o mongoose

Ratan Uday Kumar

Eu quero realizar a soma de pontos de funcionários de documentos mongodb.

Meus documentos em coleções de pontos de funcionários são como abaixo

[
    {
        "EmployeeID": "Cust0001",
        "Point": 1,
    },
    {
        "EmployeeID": "Cust0002",
        "Point": 2,
    },
    {
        "EmployeeID": "Cust0003",
        "Point": 1,
    },
    {
        "EmployeeID": "Cust0001",
        "Point": 5,
    },
    {
        "EmployeeID": "Cust0001",
        "Point": 2,
    }
]

Resultado esperado

[
    {
        "EmployeeID": "Cust0001",
        "Total_Points": 8
    },
    {
        "EmployeeID": "Cust0002",
        "Total_Points": 2
    },
    {
        "EmployeeID": "Cust0003",
        "Total_Points": 1
    }
]

Qual é a maneira melhor e mais otimizada de obter a saída do mongodb com o total de pontos.

Estou usando a conexão mongoose mongodb em meu projeto.

Posso manipular dados usando um loop for, mas parece bastante ineficaz.

Desde já, obrigado.

Comentários são bem-vindos.

Ashh

Você precisa usar $sumduas vezes aqui ... Um como "acumulador" para o $groupestágio e outro para somarPoints

db.collection.aggregate([
  { "$group": {
    "_id": "$EmployeeID",
    "Point": {
      "$sum": {
        "$sum": "$Point"
      }
    }
  }},
  { "$project": {
    "EmployeeID": "$_id",
    "Point": "$Point",
    "_id": 0
  }}
])

Ouput

[
  {
    "EmployeeID": "Cust0003",
    "Point": 1
  },
  {
    "EmployeeID": "Cust0002",
    "Point": 2
  },
  {
    "EmployeeID": "Cust0001",
    "Point": 8
  }
]

Verifique aqui

Este artigo é coletado da Internet.

Se houver alguma infração, entre em [email protected] Delete.

editar em
0

deixe-me dizer algumas palavras

0comentários
loginDepois de participar da revisão

Artigos relacionados

TOP lista

quentelabel

Arquivo