上一章节中我们学习了使用 MongoDB 的引用来规范数据结构文档
MongoDB 引用有两种
- 手动引用 ( Manual References )
- DBRefs
DBRefs vs 手动引用
假如有这样一个场景,在不同的集合中 ( address_home, address_office, address_mailing, 等) 存储不同的地址 ( 住址,办公室地址,邮件地址等 )
这样,我们在调用不同地址时,也需要指定集合,一个文档从多个集合引用文档,我们应该使用 DBRefs
DBRefs
MongoDB DBRef 格式
{ $ref : , $id : , $db : }
三个字段表示的意义为:
- $ref : 集合名称
- $id : 引用的id
- $db : 数据库名称,可选参数
下面的范例中用户数据文档使用了 DBRef, 字段 address
{
"_id" : ObjectId("59ee8457a0f7c7d445f864aa"),
"name" : "dabaicai",
"tel" : "13866668888",
"birthday" : "11-11"
"address": {
"$ref": "address_home",
"$id": ObjectId("59ee861ba0f7c7d445f864ac"),
"$db": "cmsblogs"
}
}
address DBRef 字段指定了引用的地址文档是在 address_home 集合下的 cmsblogs 数据库,id 为 59ee861ba0f7c7d445f864ac
下面的代码通过指定 $ref 参数(address_home 集合)来查找集合中指定 id 的用户地址信息
> var user = db.users.findOne({"name":"dabaicai"})
> var dbRef = user.address
> db[dbRef.$ref].findOne({"_id":(dbRef.$id)})
运行以上命令,返回了 address_home 集合中的地址数据
{
"_id" : ObjectId("59ee861ba0f7c7d445f864ac"),
"pincode" : 100007,
"user" : "dabaicai",
"city" : "Pek",
"state" : "China",
"building" : "东城区东四君临天下大酒店 220220"
}
最新评论
徒弟可以A师傅,学生可以A老师,为什么外包不能A正式,我觉得很正常。异性相吸这是宇宙真理
PHP天下第一(狗头叼花)
第一个不需要关注公主号直接给激活码的帖子!
客户端超时断开后,服务端如果没有设置超时机制,那也会继续等待处理,万一这期间有消息到了,那不是就接受到消息处理了,但是也没有办法返回到客户端,导致消息丢失。
企业级GO项目开发实战 Kubernetes权威指南 第六版
https://pan.baidu.com/s/1q3bnTncIACKoTZFxvx7BQw?pwd=ii7n
RabbitMQ精讲,项目驱动落地,分布式事务拔高 有吗?
Spring Cloud Alibaba 微服务架构实战 https://pan.baidu.com/s/1jF5voFRoeF0lYAzAPBWSbw?pwd=chqk