0

作为升级脚本的一部分,我想用来$where查找 id 与其中一个字段匹配的文档。我知道这很慢,因为它是用光标完成的,但这对我来说没问题;我只会运行一次。但我无法让它工作:

> db.things.drop()
true

> stuff = {}
{ }

> db.things.save(stuff)

> stuff.original_id = stuff._id
ObjectId("4ff5f9f97fadec5abb7b5392")

> db.things.save(stuff)

//why doesn't this return anything?
> db.things.find({$where: "this._id == this.original_id"})

//interstingly, this works fine
> db.things.find({$where: "this._id == this._id"})
{ "_id" : ObjectId("4ff5f9f97fadec5abb7b5392"), "original_id" : ObjectId("4ff5f9f97fadec5abb7b5392") }

这里有什么问题?为什么我不能_id比较original_id

4

1 回答 1

1

ObjectId是一个对象。此处的==运算符测试引用相等性。

> ObjectId("4ff5fbed3a015a91f85e80bb") == ObjectId("4ff5fbed3a015a91f85e80bb")
false    

但是如果操作数是更简单的类型(数字或字符串),它会检查值是否相等。

> '4ff5fbed3a015a91f85e80bb' == '4ff5fbed3a015a91f85e80bb'
true

因此,这个简单的解决方法将起作用:

> db.where.find({$where: "this._id.toString() == this.orig_id.toString()"})
{ "_id" : ObjectId("4ff5fbed3a015a91f85e80bb"), "orig_id" : ObjectId("4ff5fbed3a015a91f85e80bb") }

这是一篇关于 Javascript 中比较运算符的更多信息的帖子

这是另一篇文章

于 2012-07-05T20:51:14.183 回答