IDEA2023.1.3破解,IDEA破解,IDEA 2023.1破解,最新IDEA激活码

三十七、MongoDB 数据库引用

IDEA2023.1.3破解,IDEA破解,IDEA 2023.1破解,最新IDEA激活码

文章永久连接:https://tech.souyunku.com/?p=3705
上一章节中我们学习了使用 MongoDB 的引用来规范数据结构文档

MongoDB 引用有两种

1、 手动引用 ( Manual References )
2、 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" : "penglei",
   "tel" : "13866668888",
   "birthday" : "11-11"
   "address": {
      "$ref": "address_home",
      "$id": ObjectId("59ee861ba0f7c7d445f864ac"),
      "$db": "souyunku"
   }
}

address DBRef 字段指定了引用的地址文档是在 address_home 集合下的 souyunku 数据库,id 为 59ee861ba0f7c7d445f864ac

下面的代码通过指定 $ref 参数(address_home 集合)来查找集合中指定 id 的用户地址信息

> var user = db.users.findOne({"name":"penglei"})
> var dbRef = user.address
> db[dbRef.$ref].findOne({"_id":(dbRef.$id)})

运行以上命令,返回了 address_home 集合中的地址数据

{
   "_id" : ObjectId("59ee861ba0f7c7d445f864ac"),
   "pincode" : 100007,
   "user" : "penglei",
   "city" : "Pek",
   "state" : "China",
   "building" : "东城区东四君临天下大酒店 220220"
}

干货推荐

本站推荐:精选优质专栏

附录:MongoDB 教程:系列文章


Warning: A non-numeric value encountered in /data/wangzhan/tech.souyunku.com.wp/wp-content/themes/dux/functions-theme.php on line 1154
赞(77) 打赏



未经允许不得转载:搜云库技术团队 » 三十七、MongoDB 数据库引用

IDEA2023.1.3破解,IDEA破解,IDEA 2023.1破解,最新IDEA激活码
IDEA2023.1.3破解,IDEA破解,IDEA 2023.1破解,最新IDEA激活码

评论 抢沙发

大前端WP主题 更专业 更方便

联系我们联系我们

觉得文章有用就打赏一下文章作者

微信扫一扫打赏

微信扫一扫打赏


Fatal error: Uncaught Exception: Cache directory not writable. Comet Cache needs this directory please: `/data/wangzhan/tech.souyunku.com.wp/wp-content/cache/comet-cache/cache/https/tech-souyunku-com/index.q`. Set permissions to `755` or higher; `777` might be needed in some cases. in /data/wangzhan/tech.souyunku.com.wp/wp-content/plugins/comet-cache/src/includes/traits/Ac/ObUtils.php:367 Stack trace: #0 [internal function]: WebSharks\CometCache\Classes\AdvancedCache->outputBufferCallbackHandler() #1 /data/wangzhan/tech.souyunku.com.wp/wp-includes/functions.php(5109): ob_end_flush() #2 /data/wangzhan/tech.souyunku.com.wp/wp-includes/class-wp-hook.php(303): wp_ob_end_flush_all() #3 /data/wangzhan/tech.souyunku.com.wp/wp-includes/class-wp-hook.php(327): WP_Hook->apply_filters() #4 /data/wangzhan/tech.souyunku.com.wp/wp-includes/plugin.php(470): WP_Hook->do_action() #5 /data/wangzhan/tech.souyunku.com.wp/wp-includes/load.php(1097): do_action() #6 [internal function]: shutdown_action_hook() #7 {main} thrown in /data/wangzhan/tech.souyunku.com.wp/wp-content/plugins/comet-cache/src/includes/traits/Ac/ObUtils.php on line 367