我发现这个问题在c#和Perl中都有答案,但在本机接口中没有。我觉得这样会有用:
db.theColl。find({_id: ObjectId("4ecbe7f9e8c1c9092c000027")})
查询没有返回任何结果。我找到了4ecbe7f9e8c1c9092c000027通过做db. colll .find()和抓取一个ObjectId。这个集合中有几千个对象。
我在mongodb.org网站上读了所有能找到的页面都没找到。这样做很奇怪吗?这对我来说很正常。
我发现这个问题在c#和Perl中都有答案,但在本机接口中没有。我觉得这样会有用:
db.theColl。find({_id: ObjectId("4ecbe7f9e8c1c9092c000027")})
查询没有返回任何结果。我找到了4ecbe7f9e8c1c9092c000027通过做db. colll .find()和抓取一个ObjectId。这个集合中有几千个对象。
我在mongodb.org网站上读了所有能找到的页面都没找到。这样做很奇怪吗?这对我来说很正常。
当前回答
如果你正在研究mongo shell,请参考这个:来自Tyler Brock的回答
如果你使用node.js使用mongodb,我写了答案
你不需要把id转换成一个ObjectId。只需使用:
db.collection.findById('4ecbe7f9e8c1c9092c000027');
这个收集方法会自动将id转换为ObjectId。
另一方面:
db.collection.findOne({"_id":'4ecbe7f9e8c1c9092c000027'})没有正常工作。您已经手动将id转换为ObjectId。
可以这样做:
let id = '58c85d1b7932a14c7a0a320d';
let o_id = new ObjectId(id); // id as a string is passed
db.collection.findOne({"_id":o_id});
其他回答
如果你正在研究mongo shell,请参考这个:来自Tyler Brock的回答
如果你使用node.js使用mongodb,我写了答案
你不需要把id转换成一个ObjectId。只需使用:
db.collection.findById('4ecbe7f9e8c1c9092c000027');
这个收集方法会自动将id转换为ObjectId。
另一方面:
db.collection.findOne({"_id":'4ecbe7f9e8c1c9092c000027'})没有正常工作。您已经手动将id转换为ObjectId。
可以这样做:
let id = '58c85d1b7932a14c7a0a320d';
let o_id = new ObjectId(id); // id as a string is passed
db.collection.findOne({"_id":o_id});
对于 Python 主义者:
import pymongo
from bson.objectid import ObjectId
...
for row in collectionName.find(
{"_id" : ObjectId("63ae807ec4270c7a0b0f2c4f")}):
print(row)
在MongoDB Stitch函数中,可以使用BSON完成,如下所示:
使用BSON实用程序包中的ObjectId helper来实现此目的,如下例所示:
var id = "5bb9e9f84186b222c8901149";
BSON.ObjectId(id);
您错过插入双引号。 准确查询是
db.theColl.find( { "_id": ObjectId("4ecbe7f9e8c1c9092c000027") } )
我只是有这个问题,并完全按照文档做,但它仍然不工作。
查看错误消息,确保没有复制任何特殊字符。我得到了错误
SyntaxError: illegal character @(shell):1:43
当我转到第43号字符时,它只是我的对象ID的开始,在双引号之后,就像我粘贴进来的那样。我把光标放在那里,按退格键,当它应该删除开引号时,什么都没有发生。我再次按退格键,它删除了开引号,然后我把引号放回并执行查询,它工作了,尽管看起来完全相同。
我在WebMatrix中进行开发,并从控制台复制了对象id。无论何时在WebMatrix中从控制台复制,您都可能选择一些会导致错误的不可见字符。