sql >> Database >  >> NoSQL >> MongoDB

Zoek met behulp van _id werkt niet met aggregatie

Mongoose cast geen String naar ObjectId in geaggregeerde functie. Je moet het dus handmatig casten met mangoest.

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. Kan ik twee kolommen uniek voor elkaar maken? of samengestelde primaire sleutels in redis gebruiken?

  2. MongoDB $ radialenToDegrees

  3. MongoDB $anyElementTrue

  4. Hoe de $set Update Operator werkt in MongoDB