【金秋打卡】第6天 使用$lookup进行多集合查询和 MongoDB 数据库设计
2022/10/31 4:25:01
本文主要是介绍【金秋打卡】第6天 使用$lookup进行多集合查询和 MongoDB 数据库设计,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
课程名称:web前端架构师
课程章节:第14周 第七章 mongodb 高级内容
主讲老师:张轩
课程内容: 使用$lookup进行多集合查询和 mongodb 数据库设计原则
使用$lookup进行多集合查询
$lookup 类似关系型数据库的 join
$lookup 的写法
db.users.aggregate([{ $lookup: { from: collection, localField: field, foreignField: field, as: result } }])
其中
- from 连接集合的名称
- localField 需要的字段名
- foreignField 被连接集合的字段名
- as 新的字段名,可以与原来的字段名同名,但会覆盖原来的字段名
例如我想想要从球员集合 users 中查找到他们的球队 teams 信息
db.users.aggregate([{ $lookup: { from: 'teams', localField: 'team', foreignField: '_id', as: 'team' } }])
MongoDB 数据库设计
MongoDB 最佳设计实践。 https://www.mongodb.com/developer/products/mongodb/mongodb-schema-design-best-practices
数据设计时,我们的关键问题就是选择内嵌,还是引用
内嵌
内嵌的优势
- 只需要一次查询就可以查询到所有信息
- 避免多集合查询
- 只需要一个操作就可以更新多个信息
内嵌的劣势
- 单个文档太大,查询可能更耗时,获得的无关信息增大
- 针对每个文档,MongoDB 有个 16M 的最大限制,内嵌太多,可能超过这个限制。
引用
引用的优势
- 将数据分散的不同的文档,数据量会变小
- 不太会炒超过 16M 的限制
- 每次查询取得不必要的数据概率降低
引用的劣势
- 需要多次查询才能获得最终数据
数据设计
- 一个对几个,推荐使用内嵌
- 一个对很多个,推荐使用引用。可以使用下面两种方式
- 在子集合中,使用一个字段保存父集合的 id
- 在父集合中,使用一个数组保存所有子集合的 id
当我们需要在子集合中有对数据进行排序的时候,建议使用第二种方式
这篇关于【金秋打卡】第6天 使用$lookup进行多集合查询和 MongoDB 数据库设计的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-20go-zero 框架的 RPC 服务 启动start和停止 底层是怎么实现的?-icode9专业技术文章分享
- 2024-12-19Go-Zero 框架的 RPC 服务启动和停止的基本机制和过程是怎么实现的?-icode9专业技术文章分享
- 2024-12-18怎么在golang中使用gRPC测试mock数据?-icode9专业技术文章分享
- 2024-12-15掌握PageRank算法核心!你离Google优化高手只差一步!
- 2024-12-15GORM 中的标签 gorm:"index"是什么?-icode9专业技术文章分享
- 2024-12-11怎么在 Go 语言中获取 Open vSwitch (OVS) 的桥接信息(Bridge)?-icode9专业技术文章分享
- 2024-12-11怎么用Go 语言的库来与 Open vSwitch 进行交互?-icode9专业技术文章分享
- 2024-12-11怎么在 go-zero 项目中发送阿里云短信?-icode9专业技术文章分享
- 2024-12-11怎么使用阿里云 Go SDK (alibaba-cloud-sdk-go) 发送短信?-icode9专业技术文章分享
- 2024-12-10搭建个人博客网站之一、使用hugo创建个人博客网站