2012-04-20 35 views

回答

19

你的意思是你有一个ObjectId的24位十六进制数字字符串?

假设这就是你的意思,大多数驱动程序有一个方法来获取一个字符串并将其转换为ObjectId。在JavaScript中这是:

.find({_id:new ObjectId("4f91bfcfaa7c5687a0c686d4")}) 

更新成为(在https://github.com/christkv/node-mongodb-native从文档)的节点本地驱动程序更有用些:

// Get the objectID type 
var ObjectID = require('mongodb').ObjectID; 

var idString = '4e4e1638c85e808431000003'; 
collection.findOne({_id: new ObjectID(idString)}, console.log) // ok 
collection.findOne({_id: idString}, console.log) // wrong! callback gets undefined 
+0

是的,您了解我的问题。对不起,可能不是很好,'_id's是默认的mongo bson对象。发送json到客户端时它们会发生变异,因此它们首先被转换为字符串。当他们回到服务器时,我需要将它们变回对象以查询与他们的数据库? – fancy 2012-04-20 23:40:11

+0

是的,查询你需要再次将它们转换为ObjectId。 – 2012-04-21 01:34:43

+0

好吧,感谢信息 – fancy 2012-04-21 03:36:36

1

如果您的_id值是字符串,您可以像查询其他字段一样查询它们。 (记住,如果你正在为_id设置自定义值,它们必须保持唯一,否则你将得到一个重复键错误。)

这里是蒙戈JS壳牌为例:

> db.test.insert({_id:"stringID1"}) 
> db.test.insert({_id:"stringID2"}) 
> db.test.insert({_id:"stringID3"}) 
> db.test.find({_id:"stringID1"}) 
{ "_id" : "stringID1" } 
> 

这是你在找什么?我希望我没有误解你的问题!

+0

这实际上回答了**问**的问题,但显然不是她想要问的问题** ^^ – 2016-12-13 08:32:48