mongdb monk -Argument传入的必须是12个字节的单个字符串或24个十六进制字符的字符串

时间:2018-04-06 06:10:05

标签: node.js mongodb monk

我遇到错误:传入的参数必须是12个字节的单个字符串或24个十六进制字符的字符串。当我尝试使用在先前查询中获得的ID查找查询时。我尝试将它们作为ObjectIds进行投射,但它给了我同样的错误。非常感谢您的帮助。以下是我的代码:

           var bookIds = []
           for(var j = 0; j < cart.length; j++){
               bookIds.push(cart[j].bookId);
           }
           bookCollection.find({_id:{$in:bookIds}}, {}, function(err, books){
                if(err !== null){
                    console.log(err);
                    res.send({"msg":"Add to cart error"});
                }   
                if(books){
                    console.log("new cart");
                    console.log(cart);
                    console.log(books);
                    res.json(books);
                }
                else{
                    res.send({"msg":"Add to cart error"});
                }
           });

购物车内容:

[ { bookId: '5ac5cdf3532808df2e80281e', quantity: 3 },
  { bookId: '5ac5d30479705c2a30a0c235', quantity: 4 },
  { bookId: '5ac5cdfd532808df2e80281f', quantity: 1 },
  { bookId: '5ac5cfe379705c2a30a0c23', quantity: '2' } ]

2 个答案:

答案 0 :(得分:0)

当您将它们存储为其他模型的ObjectIdObjectId时,您无需投放它们ref

const bookIds = cart.map({bookId} => bookId);
bookCollection.find({ "_id" :{ "$in": bookIds }})
.then(books => {
     console.log("new cart");
     console.log(cart);
     console.log(books);
     res.json(books);
})
.catch(err => {
     console.log(err);
     res.send({"msg":"Add to cart error"});
})

答案 1 :(得分:0)

这是因为_id必须是Mongoose.Types.ObjectId

类型

解决:

objectId = require('mongoose').Types.ObjectId;

 for(var j = 0; j < cart.length; j++){
   bookIds.push(new objectId(cart[j].bookId));
 }
相关问题