Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/mongodb/11.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Mongodb Mongo Db手册参考_Mongodb_Manual - Fatal编程技术网

Mongodb Mongo Db手册参考

Mongodb Mongo Db手册参考,mongodb,manual,Mongodb,Manual,我在手册参考方面有一个问题。有人能帮忙吗?“用户”数据库中有以下两个集合: MongoDB Enterprise > db.myUser.find().pretty() { "_id" : ObjectId("585beb14efb2d0abae8bcfe5"), "name" : "Tom Benzamin", "contact" : "987654321", "dob" : "01-01-1991", "a

我在手册参考方面有一个问题。有人能帮忙吗?“用户”数据库中有以下两个集合:

MongoDB Enterprise > db.myUser.find().pretty()
{
        "_id" : ObjectId("585beb14efb2d0abae8bcfe5"),
        "name" : "Tom Benzamin",
        "contact" : "987654321",
        "dob" : "01-01-1991",
        "address" : [
                ObjectId("58599187efb2d0abae8bcfdf"),
                ObjectId("58599187efb2d0abae8bcfe0")
        ]
}

MongoDB Enterprise > db.myAddress.find().pretty()
{
        "_id" : ObjectId("58599187efb2d0abae8bcfdf"),
        "building" : "22 A, Indiana Apt",
        "pincode" : 123456,
        "city" : "Los Angeles",
        "state" : "california"
}
从结果变量中的“myUser”集合中选择地址:

MongoDB Enterprise > var result = db.myUser.find({},{_id:0,address:1})

MongoDB Enterprise > result
{ "address" : [ ObjectId("58599187efb2d0abae8bcfdf"), ObjectId("58599187efb2d0abae8bcfe0") ] }
通过匹配myUser集合从myAddress集合中获取数据:

MongoDB Enterprise > var Final = db.myAddress.find({_id:{$in:result["address"]}}
)
以下是错误:

MongoDB Enterprise > Final
Error: error: {
        "ok" : 0,
        "errmsg" : "$in needs an array",
        "code" : 2,
        "codeName" : "BadValue"
}

如何解决此问题?

在find()查询中返回的值是一个游标,因此如果打印该值,游标将迭代,该值将丢失。如果要“保留”内容,请调用.next()(正如cdbajorin所建议的)或.toArray()


find()查询中返回的值是一个游标,因此如果打印该值,游标将迭代,该值将丢失。如果要“保留”内容,请调用.next()(正如cdbajorin所建议的)或.toArray()


您可以使用
toArray()
,而不是
next()
,这样您就不必按数组位置进行访问。非常感谢您的回复。您如何知道它返回了一个光标?@Ravi,因为它位于for
。find()
而不是
toArray()
,您可以使用
next()
因此您不必按数组位置访问。非常感谢您的回复。您如何知道它返回了一个光标?@Ravi,因为它位于for
.find()中。
> var result = db.myUser.find({},{_id:0,address:1}).next()

> result
    {
        "address" : [
            ObjectId("58599187efb2d0abae8bcfdf"),
            ObjectId("58599187efb2d0abae8bcfe0")
        ]
    }

>var Final = db.myAddress.find({_id:{$in:result.address}})

>Final

{ "_id" : ObjectId("58599187efb2d0abae8bcfdf"), "building" : "22 A, Indiana Apt", "pincode" : 123456, "city" : "Los Angeles", "state" : "california" }