学习mongo系列(十一)关系
准备工作:首先在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系列(十一)关系的更多相关文章
- 学习mongo系列(八)密码与权限
一.设置密码及用户角色[1] > db.createUser(... {... user: "maxh",... pwd: "123",... roles ...
- 学习mongo系列(六)limit(munber),skip(number)
> db.user.find().pretty(){ "_id" : ObjectId("56946fba3a18f4867aecbcd1"), &quo ...
- 学习mongo系列(一) win/mac安装 解析 连接
一.安装mongo数据库 下载链接https://www.mongodb.org/downloads, 在执行如下命令的时候事先按照目录新建如下的目录:(如果数据库安装在D盘就在D盘的根目录下建)&q ...
- 学习mongo系列(十)MongoDB 备份(mongodump)与恢复(mongorerstore) 监控(mongostat mongotop)
一.备份 在Mongodb中我们使用mongodump命令来备份MongoDB数据.该命令可以导出所有数据到指定目录中. mongodump命令可以通过参数指定导出的数据量级转存的服务器. mongo ...
- 学习mongo系列(九)索引,聚合,复制(副本集),分片
一.索引 二.聚合 三.复制(副本集) 四.分片 尚未实践操作. 详见http://www.runoob.com/mongodb/mongodb-indexing.html
- 学习mongo系列(七)aggregate() ,$group() 管道
aggregate()聚合,主要用于处理数据(诸如统计平均值,求和等),并返回计算后的数据结果.有点类似sql语句中的 count(*) 接上边的数据库: > db.user.aggregate ...
- 学习mongo系列(五) AND,$or,$type
MongoDB OR 条件 MongoDB OR 条件语句使用了关键字 $or,语法格式如下: >db.col.find( { $or: [ {key1: value1}, {key2:valu ...
- 学习mongo系列(四) find().pretty() remove() 查询
一.find() 方法以非结构化的方式来显示所有文档.如果你需要以易读的方式来读取数据,可以使用 pretty() 方法,语法格式如下:db.collection_name.find().pretty ...
- 学习mongo系列(三) update() save()
一.update()方法 >db.user.update({"name":"user1"},{$set:{"title":" ...
随机推荐
- Oracle 10g ORA-01034: ORACLE not available 错误
今天在开发系统的时候,刚开始还好好的,突然就遇到了一个错误 ORA-01034: ORACLE not available 感到莫名其妙.然后排查问题 监听器ok,各项服务ok. 最后解决办法如下: ...
- UIAlertController 的使用
IAlertController 同时替代了 UIAlertView 和 UIActionSheet,从系统层级上统一了 alert 的概念 —— 即以 modal 方式或 popover 方式展示. ...
- gets(),fgets()的作用机制探究
gets(),fgets() scanf("%d",&a)若接受形如 2 这样的输入后,缓冲区内会留一个\n,此后若调用gets等函数时会读出这个换行出现错误,需注意 fg ...
- IOS 单例模式的写法
iOS的单例模式有两种官方写法,如下: 1)不使用GCD的方式 #import "Manager.h" static Manager *manager; @implementati ...
- http://blog.csdn.net/ClementAD/article/category/6217187/2
http://blog.csdn.net/ClementAD/article/category/6217187/2
- eNSP的使用
1- 进入华为路由器界面配置ipThe device is running!####################################Nov 1 2016 23:39:24-08:00 ...
- MVC 区域功能
因为MVC项目是要求都放在固定的文件夹,所以,当项目大的时候,会很不方便管理,所以微软引入的区域的功能 使用方法: 在项目上右击--添加--区域 就会出现Areas的文件夹,里面就是子MVC 渲染: ...
- LaTeX插入图片方法 Inserting Images
Inserting Images Images are essential elements in most of the scientific documents. LATEX provides s ...
- SD卡读写遇到的一些函数
SD_SPI_ReadWriteByte(0XFF): 你的数据线写0xff,就是一直保持高,clk就有了8个,可以说只是发送的数据是0xff,这又不是SD的命令,但是它必须要靠控制器提供时钟才能工作 ...
- 1046: 最小的K个数
1046: 最小的K个数 时间限制: 1 Sec 内存限制: 128 MB提交: 233 解决: 200[提交][状态][讨论版] 题目描述 输入n个整数,找出其中最小的K个数.例如输入4,5,1 ...