sql >> Databáze >  >> NoSQL >> MongoDB

MongoDB :Jak znásobit pole, které se objevuje pouze v $project?

Použijte klíčové slovo addFields poté, co budeme moci použít klíč v projektu .

 const LEAD_PRICE  = ....; // doesn't matter 
  Client.aggregate(
      [
        {
          $lookup: {
            from: "clientboughtleads",
            localField: "_id",
            foreignField: "Client",
            as: "ClientLeads"
          }
        },
   {
     $addFields: {
       TotalPurchasedLeads: {
              $size: "$ClientLeads"
          }
     }
   },
        {
          $project: {
            ClientId: "$_id",
            RegistrationDate: "$date",
            TotalPurchasedLeads:1,
            IncomeFromClient: {     // This one is always undefined
              $multiply: [LEAD_PRICE / 2, "$TotalPurchasedLeads"]
            }
          }
        }
      ]


  1. Jak zapsat podmínku shody pro hodnoty pole?

  2. použijte .where() Dotaz s .update() přes mongoose?

  3. jak spustit souhrnný dotaz v klientovi mongodb na RockMongo nebo mViewer

  4. Analyzujte výkon dotazu - mongoDB