2016-10-21 147 views
3

我有一个Mongo数据库,在用户集合中我只有1个文档。 我使用用户名过滤器执行find()和findOne()操作。 我得到我认为find()操作的结果不正确。MongoDB中的find()和findOne()方法显示不同的结果

MongoDB shell version: 3.2.10 
connecting to: test 
Server has startup warnings: 
2016-10-20T20:37:32.681-0700 I CONTROL [initandlisten] 
2016-10-20T20:37:32.681-0700 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/enabled is 'always'. 
2016-10-20T20:37:32.681-0700 I CONTROL [initandlisten] **  We suggest setting it to 'never' 
2016-10-20T20:37:32.681-0700 I CONTROL [initandlisten] 
2016-10-20T20:37:32.681-0700 I CONTROL [initandlisten] ** WARNING: /sys/kernel/mm/transparent_hugepage/defrag is 'always'. 
2016-10-20T20:37:32.681-0700 I CONTROL [initandlisten] **  We suggest setting it to 'never' 
2016-10-20T20:37:32.681-0700 I CONTROL [initandlisten] 
> use lab2 
switched to db lab2 
> db.users.find() 
{ "_id" : ObjectId("5807ac0765f24dd0660e4332"), "username" : "avtrulzz", "fname" : "Abc", "lname" : "Def", "email" : "[email protected]", "password" : "rootuser", "mobile" : NumberLong(1234567890) } 
> db.users.findOne() 
{ 
    "_id" : ObjectId("5807ac0765f24dd0660e4332"), 
    "username" : "avtrulzz", 
    "fname" : "Abc", 
    "lname" : "Def", 
    "email" : "[email protected]", 
    "password" : "rootuser", 
    "mobile" : NumberLong(1234567890) 
} 
> if (db.users.find({username : "noSuchUsername"})) { 
... print ("Username exists"); 
... } else { 
... print ("User does not exist"); } 
Username exists 
> if (db.users.findOne({username : "noSuchUsername"})) { print ("Username exists"); } else { print ("User does not exist"); } 
User does not exist 
> if (db.users.findOne({username : "avtrulzz"})) { print ("Username exists"); } else { print ("User does not exist"); } 
Username exists 

见find操作将返回用户存在这是不正确的。 findOne()表现正确。 enter image description here

+0

你说的问题是前两个查询(find()与findOne())或最后一个命令(if块)的结果有差异吗?输出结果如何让你认为结果不正确? –

+0

我认为find()还应该返回“User does not exist”,因为没有用户名称为“noSuchUsername”不存在 –

回答

5

的所有第一,findOne之间的基本区别()和find():

  • findOne - 如果查询匹配,第一个文档返回,否则返回null。

  • 查找 - 无匹匹配的文档数量,返回游标,从不为空。

因此,当放入if条件时,findOne可以在与任何文档不匹配时转换为false。由于find返回一个游标对象,并且永远不会返回null,所以在放入if条件时将转换为true。

查找和findOne返回下面的空收集:

enter image description here

3

你发现自己的缺陷是从蒙戈外壳对象在JavaScript布尔值相当无证转换:

findOne()返回文件,或零/零/不管-IT-是-called

查找()返回光标,它可以是空的。但总是定义返回的对象

3

即使查询条件与任何文档都不匹配,find()方法也会返回cursor,总是truthy

在另一方面,findOne返回符合您查询条件或null(JavaScript或在你的语言驱动程序的等价物),如果没有符合指定条件的文档头文件

> db.dropDatabase() 
{ "dropped" : "test", "ok" : 1 } 
> var cursor = db.collection.find(); 
> cursor; 
> typeof cursor; 
object 
> !cursor; 
false 
> var document = db.collection.findOne(); 
> document; 
null 
> typeof document; 
object 
> !document; 
true 
1

也许发现不是布尔检查正确的候选人,即使没有数据则返回一个空指针,其通过在布尔为真

if (db.users.find({username : "noSuchUsername"}).toArray().length>0) { 
... print ("Username exists"); 
... } else { 
... print ("User does not exist"); } 

if (db.users.find({username : "noSuchUsername"}).size()>0) { 
    ... print ("Username exists"); 
    ... } else { 
    ... print ("User does not exist"); } 

findOne工作正常,因为如果没有找到数据,它会返回null,在布尔检查中返回false。

相关问题