ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

MongDB- 文档对象之间的关系

2021-08-16 01:00:28  阅读:166  来源: 互联网

标签:MongDB 对象 db 文档 user 刘俊熙 id name


1. 文档对象之间的关系

  1. 一对一 (one TO one)
    - 例如: 夫妻 (一个丈夫 对应 一个妻子)
    - 在MongoDB中, 可以通过内嵌文档的形式来体现出一对一的关系

演示:
首先在 my_test数据库中创建一个集合, wifeAndHusband, 并向集合中插入数据

{
	name:"黄蓉",
	husband:{
		name:"郭靖"
	}
> db.wifeAndHusband.find().pretty()
{
        "_id" : ObjectId("6118eb8a47935623a0ff6300"),
        "name" : "黄蓉",
        "husband" : {
                "name" : "郭靖"
        }
}

一个文档对象一旦被嵌入到另一个文档对象中就绝不可能再被嵌入到其他文档对象中,因此可以体现出一对一的关系


  1. 一对多 (one TO many) / 多对一 (many TO one) 例如 :
    - 父母 To 孩子
    - 用户 To 订单
    - 文章 To 评论
  • 也可以通过内嵌文档来映射一对多的关系, 拿文章和评论举例, 一个文章可以包含多个评论, 只需要在文章中添加一个评论属性, 属性中包含的是一个数组, 数组中为多个评论对象
  • **问题**: 评论对于文章来说是可以无限多的, 但当评论中的数据多到一定程度后, 会造成单一数据库内存过大的问题,不利于维护

具体实现:
使用 用户 to 订单 距离

  1. 创建一个集合user, 插入以下数据
> db.user.insertMany([{name:'刘俊熙'},{name:'龙猫不热'}])
> db.user.find()

在这里插入图片描述

  1. 创建订单集合 order,插入数据
db.order.insertOne(
    {
    // 用户 刘俊熙对应的订单
        list:['苹果','香蕉','西瓜']
    }
)

但是这样还不能体现该订单是对应 刘俊熙数据的, 如何处理?

  • 刘俊熙数据的_id的值一起添加到 order集合中, 作为标识
db.order.insertOne(
    {
        list:['苹果','香蕉','西瓜'],
        user_id:ObjectId("6118f452928b3b5423acb15f")
    }
)

db.order.find()

在这里插入图片描述
通过唯一性的_id作为参照插入到另一个文档对象中, 由此实现 一对多的关系

查询一对多

要求: 查询刘俊熙的订单

db.user.findOne({name:"刘俊熙"})._id

在这里插入图片描述

db.order.find({user_id:db.user.findOne({name:"刘俊熙"})._id})

在这里插入图片描述


  1. 多对多 (manyTO many)
  • 分类 - 商品
  • 老师 - 学生

例如: 在teachers集合中插入以下数据

db.teachers.insert([
    {name:"洪七公"},
    {name:"黄药师"},
    {name:"龟仙人"}

    ]);

db.teachers.find()

那么,要怎么体现出多对多的关系呢?

db.stus.insert([
// 如果, 郭靖既是洪七公的徒弟又是黄药师的徒弟,要怎么在数据库中体现呢? 
    {name:"郭靖"}
])

在这里插入图片描述

体现

db.stus.insert([
    {
     name:"郭靖",
     tech_id:[
     // 添加洪七公的 _id 作为tech_id 的其中一条数据
        ObjectId("61192a9b928b3b5423acb166"),
     // 再把洪七公的 _id 也添加进来
        ObjectId("61192a9b928b3b5423acb167")
     ]
    }
])

运行
在这里插入图片描述
这时候就能体现出 多对多的关系了

标签:MongDB,对象,db,文档,user,刘俊熙,id,name
来源: https://www.cnblogs.com/long-mao-bu-re/p/15145561.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有