08、MongoDB -- MongoDB 的 集合关联($lookup 和 DBRef 实现集合关联)

目录

  • MongoDB 的 集合关联
    • 演示前提:
      • 登录单机模式的 mongodb 服务器命令
      • 登录【test】数据库的 mongodb 客户端命令
      • 登录【admin】数据库的 mongodb 客户端命令
    • SQL 术语 与 Mongodb 的对应关系
    • 使用 $lookup 实现集合关联
      • 语法格式
      • 添加测试数据
      • 1、查询出订单数量大于6,及其对应的商品:
        • 1-1:查询出订单中,【amount】数量大于6的订单
        • 1-2:查询出订单中,【amount】数量大于 6 的订单,及其对应的商品
          • 查询命令
          • 命令解释
          • 查询结果
      • 2、查询出价格为 30 的商品所关联的全部订单
        • 2-1:查询【item】集合中价格为 30 的商品:
        • 2-2:查询出价格为 30 的商品所关联的全部订单
          • 查询命令
          • 命令解释
          • 查询结果
    • 使用 DBRef 实现集合关联
      • 语法格式
      • 添加测试数据
      • 1、查询标题为 “标题2" 的 comment 及对应的商品
        • 1-1:查询标题为 “标题2" 的 comment
          • 查询命令
          • 查询结果
        • 1-2:查询标题为 “标题2" 的 comment 文档 及 对应的商品
          • 查询返回的文档只有一条数据:
            • 查询命令:
            • 查询结果
          • 查询返回的文档有多条数据:
            • 查询命令
            • 查询结果

MongoDB 的 集合关联

演示前提:


登录单机模式的 mongodb 服务器命令

mongod.exe --config "E:\install\mongodb\mongodb-4.2.25\mongod.conf"

在这里插入图片描述


登录【test】数据库的 mongodb 客户端命令

mongo mongodb://192.168.0.107:27017/test -u LJHAAA -p 123456

在这里插入图片描述


登录【admin】数据库的 mongodb 客户端命令

mongo mongodb://192.168.0.107:27017/admin -u admin -p 123456

在这里插入图片描述


SQL 术语 与 Mongodb 的对应关系


在这里插入图片描述


使用 $lookup 实现集合关联


语法格式

在聚集运算使用如下文档:

   {
     $lookup:
        {
          from: 指定要连接的集合
          localField: 指定本集合中文档的主键字段
          foreignField: 指定要连接的集合中的外键字段
          as: 指定被连接对象的属性名
     }
   }

localField 和 foreignField 指定两个集合之间的关联条件


添加测试数据

原本的 item 集合有这些数据

在这里插入图片描述

价格为 30 的【键盘】,和 订单 1、2、3相关联;
价格为 60 的【鼠标】,和 订单 4、5 相关联;

db.order.insert([
  {item_id:  ObjectId("65e6cb5e055c945aa89b8575"), name: "订单1", amount: 3},
  {item_id:  ObjectId("65e6cb5e055c945aa89b8575"), name: "订单2", amount: 5},
  {item_id:  ObjectId("65e6cb5e055c945aa89b8575"), name: "订单3", amount: 8},
  {item_id:  ObjectId("65e6cb5e055c945aa89b8578"), name: "订单4", amount: 4},
  {item_id:  ObjectId("65e6cb5e055c945aa89b8578"), name: "订单5", amount: 7}
])

如图:生成一个【order】的订单集合,相当于sql的订单表。

在这里插入图片描述


1、查询出订单数量大于6,及其对应的商品:


1-1:查询出订单中,【amount】数量大于6的订单

在这里插入图片描述


1-2:查询出订单中,【amount】数量大于 6 的订单,及其对应的商品

查询命令
 db.order.aggregate([
    {$match: {amount: {$gt: 6}}},
    { 
       $lookup: 
        {
           from: "item",
           localField: "item_id",
           foreignField: "_id",
           as: "item_detail"
        }
     }
])

命令解释
 db.order.aggregate([                  //aggregate 表示对 MongoDB 中的 order 集合执行聚集运算
 
    {$match: {amount: {$gt: 6}}},      //这是聚合管道中的第一个阶段,相当于where 条件:查询 amount > 6 的订单     
    { 
       $lookup:                        // 这是聚合管道中的第二个阶段,使用 $lookup 操作符来执行关联查询
        {
           from: "item",               //指定要连接的集合,这里是连接【item】这个集合(表)
           
           localField: "item_id",      // 指定当前集合(order)中用于关联的字段为 item_id
           
           foreignField: "_id",        //指定要关联的集合(item)中用于关联的字段为 _id
           
           as: "item_detail"           //指定将关联查询的结果存储到名为 item_detail 的字段中
        }
     }
])

相当于 SQL 中的 join 查询:

select * from order o  
join  item i  on o.item_id = i . _id 
where o.amout > 6;

在这里插入图片描述


查询结果

在这里插入图片描述


2、查询出价格为 30 的商品所关联的全部订单


2-1:查询【item】集合中价格为 30 的商品:
db.item.aggregate([
    {$match:{price:30}}
])

在这里插入图片描述


2-2:查询出价格为 30 的商品所关联的全部订单
查询命令
db.item.aggregate([
     {$match: {price: 30}},
     {$lookup: {
              from: "order",
              localField: "_id",
              foreignField: "item_id",
              as: "order_array"
          }
      }
])

命令解释
db.item.aggregate([

     {$match: {price: 30}},             //这是聚合管道中的第一个阶段,用于筛选出【item】集合中 price 等于 30 的 数据
     
     {$lookup: {    			        //这是聚合管道中的第二个阶段,使用 $lookup 操作符来执行关联查询
     
              from: "order",            //指定要关联查询的集合为 order
              
              localField: "_id",        //指定当前集合(item)中用于关联的字段为 _id
              
              foreignField: "item_id",  //指定要关联的集合(order)中用于关联的字段为 item_id
              
              as: "order_array"         //指定将关联查询的结果存储到名为 order_array 的字段中
          }
      }
])

查询结果

在这里插入图片描述


使用 DBRef 实现集合关联


语法格式

DBRef 尽可能地模拟了SQL数据库中外键——指定要引用哪个表的哪个列。

插入文档时使用 DBRef 引用其他文档,DBRef 的完整形式:

{ $ref : 被引用的集合名 , $id : 被引用的文档主键< value > , $db : 被引用的数据库 }

如果被引用的集合在同一个数据库中,$db 可以省略。

通过 DBRef 的 fetch() 方法即可抓取关联文档。


添加测试数据

db.comment.insert([
  {item:  {$ref: "item", $id: ObjectId("65e6cb5e055c945aa89b8575")}, title: "标题1", body: "评论内容1"},
  {item:  {$ref: "item", $id: ObjectId("65e6cb5e055c945aa89b8575")}, title: "标题2", body: "评论内容2"},
  {item:  {$ref: "item", $id: ObjectId("65e6cb5e055c945aa89b8575")}, title: "标题3", body: "评论内容3"},
  {item:  {$ref: "item", $id: ObjectId("65e6cb5e055c945aa89b8575")}, title: "标题4", body: "评论内容4"},
  {item:  {$ref: "item", $id: ObjectId("65e6cb5e055c945aa89b8575")}, title: "标题5", body: "评论内容5"}
])

item: 这是一个嵌套的字段,包含了一个引用到 item 集合中某个文档的信息。

$ref: “item”: 指定了引用的集合为 item。

$id: ObjectId(“65e6cb5e055c945aa89b8575”): 指定了引用的文档的 ObjectId。

如图:引用了 item 集合中的 id 为 【65e6cb5e055c945aa89b8575】 的文档

在这里插入图片描述


测试数据:

在这里插入图片描述


1、查询标题为 “标题2" 的 comment 及对应的商品


1-1:查询标题为 “标题2" 的 comment

查询命令
db.comment.findOne({title: "标题2"})

查询结果

在这里插入图片描述


1-2:查询标题为 “标题2" 的 comment 文档 及 对应的商品

【备注】如果你已经用了 DBRef 来记录关联,程序可以非常方便处理关联,压根不需要使用 $lookup


查询返回的文档只有一条数据:

查询命令:
db.comment.findOne({title: "标题2"}).item.fetch()

查询结果

在 studio 3t 这个图形界面工具查询就出错。

在这里插入图片描述


修改成这样:

db.comment.findOne({title: "标题2"}, {item: 1})

在这里插入图片描述


在命令行窗口查询就可以

在这里插入图片描述


在这里插入图片描述


查询返回的文档有多条数据:

如果查询的包含了多个文档,且要通过DBRef获取关联文档时,
由于 find() 方法返回的是 DBCursor,因此需要先遍历 DBCursor,然后在通过查询文档的关联属性来获取关联的文档。

DBCursor 有一个 forEach 方法,该方法需要传入一个 JS 的 function( c ) {c就代表了正则遍历的文档},
通过该函数可对DbCursor中多个文档进行遍历。


查询命令
db.comment.find({title: "标题2"}).forEach(function(c){
    print(JSON.stringify(c) + JSON.stringify(c.item.fetch()));
})

查询结果

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/433604.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

混沌工程-经典案例分享

目录 前言 案例 1、强弱依赖不合理 2、预案不生效 3、异常数据不兼容 4、监控体系缺陷 5、系统缺整体架构设计 总结 前言 我们公司从启动混沌工程到现在已经几乎覆盖了线上的所有核心业务&#xff0c;先后进行过2000次演练共挖掘出120个漏洞。这些漏洞有些得了及时修复…

C if...else 语句

一个 if 语句 后可跟一个可选的 else 语句&#xff0c;else 语句在布尔表达式为 false 时执行。 语法 C 语言中 if…else 语句的语法&#xff1a; if(boolean_expression) {/* 如果布尔表达式为真将执行的语句 */ } else {/* 如果布尔表达式为假将执行的语句 */ }如果布尔表…

Java Day2 面向对象

这里写目录标题 1、static总结1.1 代码块1.1.1 静态代码块1.1.2 实例代码块1.1.3 小例子 2、继承2.1 权限修饰符2.2 方法重写2.3 子类访问成员特点2.4子类构造器的特点 3、多态4、final、常量4.1 final4.2 常量 5 抽象类5.1 概念5.2 模板设计方法 6、接口6.1 接口新方法6.2 接口…

openEuler学习——部署MGR集群

本文介绍如何利用GreatSQL 8.0.25构建一个三节点的MGR集群。 1.安装准备 IP端口角色192.168.20.1103306mgr1192.168.20.1113306mgr2192.168.20.1123306mgr3 配置hosts解析 [rootMGR1 ~]# cat >> /etc/hosts << EOF > 192.168.20.110 MGR1 > 192.168.20.1…

Qt QtCreator打开pro项目时出现假死现象

在Windows系统下&#xff0c;QtCreator打开pro项目时出现假死现象&#xff0c;左侧项目树形图无法展开&#xff0c;项目根节点一直在转圈。尝试关掉所有QtCreator进程&#xff0c;重新打开pro也是无济于事。 解决方案&#xff1a; 打开“运行”窗口&#xff08;快捷键&#x…

overleaf latex 笔记

overleaf: www.overleaf.com 导入.tex文件 1.代码空一行&#xff0c;代表文字另起一段 2. 1 2 3 排序 \begin{enumerate} \item \item \item \end{enumerate} 3.插入图片 上传图片并命名 \usepackage{float}导包\begin{figure}[H]&#xff1a;表示将图…

鸿蒙开发报错解决方案: cannot be smaller than version 10 declared in library [:library]

由于报错信息不详&#xff0c;即使给hvigor.js 提供--stacktrace 级别的日志也无法定位具体模块。 解决方案&#xff1a;修改编译源码js。 1、定位具体js&#xff1a;我的定位是&#xff1a;/Users/xdg/.hvigor/project_caches/489b334bc29a5a8428674c766cdae532/workspace…

智能边缘计算网关实现工业自动化与数据处理的融合-天拓四方

随着物联网&#xff08;IoT&#xff09;技术的迅速发展和普及&#xff0c;越来越多的设备被连接到互联网上&#xff0c;产生了海量的数据。如何有效地处理和分析这些数据&#xff0c;同时确保数据的安全性和实时性&#xff0c;成为了摆在企业面前的一大挑战。智能边缘计算网关作…

图像处理与视觉感知---期末复习重点(1)

文章目录 一、概述二、图像处理基础2.1 视觉感知要素2.2 像素间的一些基本关系2.2.1 相邻像素2.2.2 连通性2.2.3 距离度量 2.3 基本坐标变换2.4 空间变换与灰度值 一、概述 1. 图像的概念及分类。  图像是用各种观测系统以不同形式和手段观测客观世界而获得的、可以直接或间接…

百度AI已经实现盈利,普通人如何通过AI短视频直播拿到结果?

从百度最新的财报数据来看&#xff0c;百度AI为广告业务、智能云业务带来了增长动力。除了直接带来商业收入&#xff0c;AI还为百度带来了新增长。2023年&#xff0c;百度用户总数、用户时长及用户粘性、付费率等都有所增加。数据显示&#xff0c;2023年12月&#xff0c;百度Ap…

刚刚,OpenAI官方发文驳斥马斯克,自曝8年间邮件往来截图

文章开篇表示&#xff1a;「OpenAI 的使命是确保 AGI 惠及全人类&#xff0c;这意味着既要构建安全、有益的 AGI&#xff0c;又要帮助创造广泛的利益。我们正在分享我们在实现使命方面所学到的知识&#xff0c;以及有关我们与马斯克关系的一些事实。我们打算驳回马斯克的所有主…

Spring事务管理与模板对象

1.事务管理 1.事务回顾 事务指数据库中多个操作合并在一起形成的操作序列 事务的作用 当数据库操作序列中个别操作失败时&#xff0c;提供一种方式使数据库状态恢复到正常状态&#xff08;A&#xff09;&#xff0c;保障数据库即使在异常状态下仍能保持数据一致性&#xff…

Netty权威指南——基础篇5 IO基础 备份

1 什么是I/O 在UNIX世界里一切皆是文件&#xff0c;而文件是什么&#xff1f;文件就是一串二进制流而已&#xff0c;其实不管是Socket&#xff0c;还是FIFO&#xff08;先进先出队列&#xff09;、管道、终端。对计算机来说&#xff0c;一切都是文件&#xff0c;一切都是流。在…

JSP实现数据传递与保存

1.HTML页面转换JSP页面 直接再HTML页面最顶端添加page指令&#xff0c;修改文件后缀名&#xff1b;反之&#xff1b; 2.JSP内置对象 对象 描述 request 每当客户端请求JSP页面时&#xff0c;JSP引擎会制造一个新的request对象来代表这个请求。 response 当服务器创建req…

内存溢出(OOM)-汇总指南

目录 java.lang.OutOfMemoryError:Java heap space 原因分析 示例 解决方案 java.lang.OutOfMemoryError:GC overhead limit exceeded 原因分析 示例 解决方案 java.lang.OutOfMemoryError:Permgen space 原因分析 示例 解决方案 java.lang.OutOfMemoryError:Metas…

Learn C the hard way :一些简单问题处理

Preface&#xff1a;本次学习主要是以复习态度而来&#xff0c;意在加强C语言的理解&#xff0c;本文主要针对于网站中出现的一些问题 我的简单Makefile&#xff1a; CFLAGS-Wall cc gcc cflag -Wall -g allfiles ex1.c ex2.c ex3.c ex4.c ex5.c ex4-1.c objs $(allfiles:.c…

Claude 3击败GPT-4,地表最强AI易主,坐等翻车

北京时间3月4日晚22点00分&#xff0c;Claude 3发布了&#xff0c;一举超越了GPT-4&#xff01; 震惊&#xff0c;居然有人能超越霸主地位&#xff0c;赶紧进官网详细的看一下&#xff1a; https://www.anthropic.com/news/claude-3-family 刷到第一的成绩单 Claude3 Opus的…

MyBatis操作数据库(SQL注入)

本文主要来讲解6大标签&#xff0c;以便更好的MyBatis操作数据库&#xff01; <if>标签<trim>标签<where>标签<set>标签<foreach>标签<include>标签 前提需求&#xff1a; MyBatis是一个持久层框架&#xff0c;和Spring没有任何关系&…

java VR全景商城 saas商城 b2b2c商城 o2o商城 积分商城 秒杀商城 拼团商城 分销商城 短视频商城 小程序商城搭建

1. 涉及平台 平台管理、商家端&#xff08;PC端、手机端&#xff09;、买家平台&#xff08;H5/公众号、小程序、APP端&#xff08;IOS/Android&#xff09;、微服务平台&#xff08;业务服务&#xff09; 2. 核心架构 Spring Cloud、Spring Boot、Mybatis、Redis 3. 前端框架…

Nodejs 第五十章(lua的基本使用)

lua基本使用 全局变量局部变量 全局变量是在全局作用域中定义的变量&#xff0c;可以在脚本的任何地方访问。全局变量在定义时不需要使用关键字&#xff0c;直接赋值即可。 xiaoman xmzsprint(xiaoman)局部变量是在特定作用域内定义的变量&#xff0c;只能在其所属的作用域…