sql >> Databasteknik >  >> NoSQL >> MongoDB

Hitta att använda _id fungerar inte med aggregering

Mongoose kastar inte String till ObjectId i aggregerad funktion. Så du måste gjuta den manuellt med mongoose.

var mongoose = require('mongoose')

const existedRelation = await this.model.aggregate([
  { "$match": { "_id": mongoose.Types.ObjectId(firstId) } },
  { "$project": {
    "relations": {
      "$filter": {
        "input": "$links",
        "as": "link",
        "cond": {
          "$and": [
            { "$eq": ["$$link.target.entityId", `${objectIdValue}`] },
            { "$eq": ["$$link.linkTypeId", linkTypeId] }
          ]
        }
      }
    }
  }}
])



  1. MongoDB $dateFromParts

  2. Kan strikta JSON $datum användas i en MongoDB-fråga?

  3. Sortering efter maximalt matrisfält, stigande eller fallande

  4. Pub/sub-implementering i nodeJS