准备工作:首先在maxh数据库的address集合中先插入数据

> db.address.insert({child_address:"gansu"})

WriteResult({ "nInserted" : 1 })
> db.address.insert({child_address:"lanzhou"})

WriteResult({ "nInserted" : 1 })

> db.address.find().pretty()
{ "_id" : ObjectId("5695c6395e085ed70afdd224"), "child_address" : "gansu" }
{ "_id" : ObjectId("5695c67b5e085ed70afdd225"), "child_address" : "lanzhou" }

然后将address的"_id"字段更新到user集合的name:"admin"记录中

> db.user.update({name:"admin"},{$set:{address_id:[ObjectId("5695c6395e085ed70af
dd224"),ObjectId("5695c67b5e085ed70afdd225")]}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

> var result = db.user.find({"name":"admin"},{"address_id":1}).pretty()
> var addresses = db.address.find({"_id":{"$in":result["address_id"]}}).pretty()

> addresses
Error: error: {
"waitedMS" : NumberLong(0),
"ok" : 0,
"errmsg" : "$in needs an array",
"code" : 2
}错误原因:findOne()写成了find()

--------------------------------------------------------------------------------------------------------
> var result = db.user.findOne({"name":"admin"},{"address_id":1}).pretty()
2016-01-13T12:00:23.633+0800 E QUERY [thread1] TypeError: db.user.findOne(...
).pretty is not a function :
@(shell):1:18错误原因:findOne()后边好像不能使用pretty()

--------------------------------------------------------------------------------------------------------

> var result = db.user.findOne({"name":"admin"},{"address_id":1})
> result
{
"_id" : ObjectId("56946fba3a18f4867aecbcd1"),
"address_id" : [
ObjectId("5695c6395e085ed70afdd224"),
ObjectId("5695c67b5e085ed70afdd225")
]
}
> var result = db.user.findOne({"name":"admin"},{"address_id":1})这个1是什么?think,think -1也可以
> var addresses = db.address.find({"_id":{"$in":result["address_id"]}}).pretty()

> addresses
{ "_id" : ObjectId("5695c6395e085ed70afdd224"), "child_address" : "gansu" }
{ "_id" : ObjectId("5695c67b5e085ed70afdd225"), "child_address" : "lanzhou" }
>

> var result = db.user.findOne({"name":"admin"},{"address_id":-1})
> var addresses = db.address.find({"_id":{"$in":result["address_id"]}}).pretty()

> addresses
{ "_id" : ObjectId("5695c6395e085ed70afdd224"), "child_address" : "gansu" }
{ "_id" : ObjectId("5695c67b5e085ed70afdd225"), "child_address" : "lanzhou" }

学习mongo系列(十一)关系的更多相关文章

  1. 学习mongo系列(八)密码与权限

    一.设置密码及用户角色[1] > db.createUser(... {... user: "maxh",... pwd: "123",... roles ...

  2. 学习mongo系列(六)limit(munber),skip(number)

    > db.user.find().pretty(){ "_id" : ObjectId("56946fba3a18f4867aecbcd1"), &quo ...

  3. 学习mongo系列(一) win/mac安装 解析 连接

    一.安装mongo数据库 下载链接https://www.mongodb.org/downloads, 在执行如下命令的时候事先按照目录新建如下的目录:(如果数据库安装在D盘就在D盘的根目录下建)&q ...

  4. 学习mongo系列(十)MongoDB 备份(mongodump)与恢复(mongorerstore) 监控(mongostat mongotop)

    一.备份 在Mongodb中我们使用mongodump命令来备份MongoDB数据.该命令可以导出所有数据到指定目录中. mongodump命令可以通过参数指定导出的数据量级转存的服务器. mongo ...

  5. 学习mongo系列(九)索引,聚合,复制(副本集),分片

    一.索引 二.聚合 三.复制(副本集) 四.分片 尚未实践操作. 详见http://www.runoob.com/mongodb/mongodb-indexing.html

  6. 学习mongo系列(七)aggregate() ,$group() 管道

    aggregate()聚合,主要用于处理数据(诸如统计平均值,求和等),并返回计算后的数据结果.有点类似sql语句中的 count(*) 接上边的数据库: > db.user.aggregate ...

  7. 学习mongo系列(五) AND,$or,$type

    MongoDB OR 条件 MongoDB OR 条件语句使用了关键字 $or,语法格式如下: >db.col.find( { $or: [ {key1: value1}, {key2:valu ...

  8. 学习mongo系列(四) find().pretty() remove() 查询

    一.find() 方法以非结构化的方式来显示所有文档.如果你需要以易读的方式来读取数据,可以使用 pretty() 方法,语法格式如下:db.collection_name.find().pretty ...

  9. 学习mongo系列(三) update() save()

    一.update()方法 >db.user.update({"name":"user1"},{$set:{"title":" ...

随机推荐

  1. .gitignore文件不起作用

    当我们用git时常常会习惯把我们不想上传到远程代码库中的一些本地文件(夹)放在一个叫做.gitignore的文件中,例如常见的本地build文件夹,一些IDE如Intellig,Eclipse的项目管 ...

  2. fopen w c

    http://php.net/manual/en/function.fopen.php

  3. [转]jni数据类型映射、域描述符说明

    在Java存在两种数据类型: 基本类型 和 引用类型 ,大家都懂的 . 在JNI的世界里也存在类似的数据类型,与Java比较起来,其范围更具严格性,如下: 1.primitive types ---- ...

  4. MySQL常用问题解决方法

    Q: # table 损坏 Table 'table_name' is marked as crashed and should be repaired A: 恢复数据表的索引:myisamchk - ...

  5. syslog-ng日志系统

    一.基础syslog-ng作为syslog的替代工具,可以完全替代syslog的服务,并且通过定义规则,实现更好的过滤功能.系统自带版本(我的是红旗,不同系统用不同的方式查询): 引用 # rpm - ...

  6. python 特殊的下划线

    Python 用下划线作为变量前缀和后缀指定特殊变量. _xxx      不能用'from module import *'导入 __xxx__ 系统定义名字 __xxx    类中的私有变量名 核 ...

  7. jQuery 中 attr() 和 prop() 方法的区别

    前几天,有人给 Multiple Select 插件 提了问题: setSelects doesn't work in Firefox when using jquery 1.9.0 一直都在用 jQ ...

  8. JQ的基本架构

    Jquery的基本架构   引入  以前学习原生JS然后切换到用JQ的时候总觉得很不习惯,甚至有点排斥用JQ.后来自己写项目一直到公司实习用JQ的这段时间,才深深感受到JQ的强大~JQ不仅做到兼容很多 ...

  9. 1.2 如何在visual studio 中建立C#程序

    这一节简单介绍一下怎么在visual studio 2015中建立第一个C#程序,我使用的是2015版的visual studio,不同版本可能有一些差异,不过大体上是相同的,这些信息仅供新手参考,大 ...

  10. 《zw版·Halcon-delphi系列原创教程》 Halcon分类函数008,matrix,矩阵函数

    ** 3dFromFundamentalMatrix( Rows1, Cols1, Rows2, Cols2, CovRR1, CovRC1, CovCC1, CovRR2, CovRC2, CovC ...