sql >> Base de Datos >  >> NoSQL >> MongoDB

Mi código API recupera una matriz de datos vacía de mongodb mientras que el código funciona bien en el área de juegos de mongodb

Resulta que la conversión del ObjectId parecía ser el problema. Necesitamos usar mongoose.Types.ObjectId

El código API se verá así

getProductByProductId: function (productId) {
return new Promise((resolve, reject) => {
  User.aggregate([
  {
  $match: {
    "shops.products._id": mongoose.Types.ObjectId(productId)
  }
  },
  {
    "$unwind": "$shops"
  },
  {
    "$unwind": "$shops.products"
  },
  {
    $match: {
    "shops.products._id": mongoose.Types.ObjectId(productId)
  }
  },
  {
  $project: {
  "_id": "$shops.products._id",
  "title": "$shops.products.title"
  }
}
])
.then(products => {
resolve(products)
}).catch(err => {
reject(err);
});
});
}