MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

Преброяване на свойство на поддокумент в проекция с помощта на MongoDB и Javascript

  • $map за повторение на цикъла на subRoom масив и in за връщане на задължителни полета
  • $filter за повторение на цикъл от notifications и $size за получаване на общия брой елементи от филтрирания резултат
db.collection.find({ id: 1 },
{
  _id: 0,
  room: 1,
  notRead: {
    $size: {
      $filter: {
        input: "$notifications",
        cond: {
          $not: { $in: ["User1", "$$this.read"] }
        }
      }
    }
  },
  "subRoom": {
    $map: {
      input: "$subRoom",
      in: {
        id: "$$this.id",
        notRead: {
          $size: {
            $filter: {
              input: "$$this.notifications",
              cond: { $not: { $in: ["User1", "$$this.read"] } }
            }
          }
        }
      }
    }
  }
})

Playground




  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Преобразувайте DBObject в POJO с помощта на MongoDB Java драйвер

  2. Грешка с дублиран ключ на MongoDB E11000

  3. използвайки низ за mongodb _id

  4. MongoDb агрегиране

  5. брой на $lookup резултат mongodb