我在这里看到过这个问题,但没有一个答案对我有用。
我的代码:
var BSON = require('mongodb').BSONPure;
// value is 544d644cf6eea12336f5e0a1
var object_id = BSON.ObjectID.createFromHexString(req.params.id);
}
// Create GET _id query
collection.find(object_id).toArray(
function (err, data) {
if (!err) {
// 200 OK
return res.status(200).send({success: true, code: 200, count: data.length, results: data});
} else {
// 500 Internal Server (Mongodb)
console.log(err);
return res.status(500).send({success: false, code: 500, error: "Internal Server Error"});
}
我已经尝试了大约五种不同的方法来通过 ObjectId 进行查找,但都没有奏效。以上是我最近的尝试。我没有从 Node 返回任何结果。当我这样做时,在 mongo shell 中:
> db.people.find({_id : ObjectId("544d644cf6eea12336f5e0a1")});
{ "_id" : ObjectId("544d644cf6eea12336f5e0a1"), "name" : "Jim", "age" : 24, "job" : "engineer" }
如您所见,我得到了一个结果。我在这里缺少什么?
最佳答案
与在mongo shell 中一样,您需要为find() 编写一个查询对象。这是示例:
var mongodb = require('mongodb');
var MongoClient = mongodb.MongoClient;
var ObjectId = mongodb.ObjectID;
MongoClient.connect('mongodb://localhost:27017/test', function(err, db) {
db.collection('people', function(err, collection) {
collection.find({_id: new ObjectId('544d644cf6eea12336f5e0a1')}).toArray(function(err, docs) {
console.log(docs);
db.close();
});
});
});
关于node.js - Node/Mongo 无法通过 ObjectId 找到,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27075700/