我对猫鼬的简单findById有麻烦。
已确认该项目存在于数据库中
db.getCollection('stories').find({_id:'572f16439c0d3ffe0bc084a4'})
与猫鼬
Story.findById(topic.storyId, function(err, res) {
logger.info("res", res);
assert.isNotNull(res);
});
不会找到的。
我也试过转换成mongoId,仍然找不到(即使mongoose应该是为你做这件事的)
var mid = mongoose.Types.ObjectId(storyId);
let story = await Story.findOne({_id: mid}).exec();
实际上,我正在尝试将它与typescript一起使用,因此使用了Await。
我也尝试了story.findbyid(id)
方法,仍然找不到。
是否有一些方法可以通过简单的_id
字段来查找项目?_id必须在模式中吗?(文件说不是)
我可以通过模式中的其他值找到,只是_id
不能使用...
更新:我为此写了一个简短的测试。
describe("StoryConvert", function() {
it("should read a list of topics", async function test() {
let topics = await Topic.find({});
for (let i = 0; i < topics.length; i ++) {
let topic = topics[i];
// topics.forEach( async function(topic) {
let storyId = topic.storyId;
let mid = mongoose.Types.ObjectId(storyId);
let story = await Story.findOne({_id: mid});
// let story = await Story.findById(topic.storyId).exec();
// assert.equal(topic.storyId, story._id);
logger.info("storyId", storyId);
logger.info("mid", mid);
logger.info("story", story);
Story.findOne({_id: storyId}, function(err, res) {
if (err) {
logger.error(err);
} else {
logger.info("no error");
}
logger.info("res1", res);
});
Story.findOne({_id: mid}, function(err, res) {
logger.info("res2", res);
});
Story.findById(mid, function(err, res) {
logger.info("res3", res);
// assert.isNotNull(res);
});
}
});
});
它会返回像这样的东西
Testing storyId 572f16439c0d3ffe0bc084a4
Testing mid 572f16439c0d3ffe0bc084a4
Testing story null
Testing no error
Testing res1 null
Testing res2 null
Testing res3 null
我注意到topic.storyid
是一个字符串,不确定这是否会导致映射到其他表的任何问题。我还尝试添加一些类型defs
storyId: {
type: mongoose.Schema.Types.ObjectId,
required: false
}
因为该查询在shell中查找文档:
db.getCollection('stories').find({_id:'572f16439c0d3ffe0bc084a4'})
这意味着文档中的_id
的类型实际上是一个字符串,而不是Mongoose所期望的objectid
。
要使用Mongoose查找该文档,必须在story
的模式中定义_id
为:
_id: { type: String }
如果您的Mongo模式被配置为使用对象Id,那么您可以在nodeJS中使用
models.foo.findById(id)
其中Foo是您的模型,id是您的id。下面是一个工作示例
router.get('/:id', function(req, res, next) {
var id = req.params.id
models.Foo.findById(id)
.lean().exec(function (err, results) {
if (err) return console.error(err)
try {
console.log(results)
} catch (error) {
console.log("errror getting results")
console.log(error)
}
})
})
在Mongo DB中,您的查询将是
{_id:ObjectId('5c09fb04ff03a672a26fb23a')}