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

Najít pomocí _id nefunguje s agregací

Mongoose neodesílá String na ObjectId v agregační funkci. Takže to musíte seslat ručně pomocí 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. $unset na více polích v mongodb

  2. Jak třídit pole uvnitř záznamu kolekce v MongoDB?

  3. Jak zastavit vkládání duplicitních dokumentů do kolekce mongodb

  4. Jak uložit geoprostorové informace v mongoDB