MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

Dodaj pole o rosnącej wartości w MongoDB Aggregation na podstawie warunku

Ta agregacja dodaje pole z licznikiem:

db.collection.aggregate( [
  { 
      $match: { 
          joining_date: { $exists: true } 
      } 
  },
  { 
      $group: { 
          _id: null, 
          docs: { $push: "$$ROOT" } 
      } 
  },
  { 
      $project: { 
          _id: 0,
         R: { 
             $map: {
                 input: { $range: [ 0, { $size: "$docs" } ] },
                 in: {
                     $mergeObjects: [ 
                         { joining_date_count: { $add: [ "$$this", 1 ] } },
                         { $arrayElemAt: [ "$docs", "$$this" ] }
                     ]
                 }
             }
         }
      }
  },
  { 
      $unwind: "$R" 
  },
  { 
      $replaceRoot: { newRoot: "$R" } 
  }
] )


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Tworzenie numerowanej listy dla danych Meteor

  2. Zapytanie o podpole w documentdb

  3. Jak uzyskać wydruk do debugowania mapy/redukcji w Mongoid?

  4. Subskrypcja kolekcji Meteor.Users

  5. Mongoose Model.find nie jest funkcją?