当前位置: 首页 > news >正文

MongoDB聚合:$unset

使用$unset阶段可移除文档中的某些字段。从版本4.2开始支持。

语法

  • 移除单个字段,可以直接指定要移除的字段名:
{ $unset: "<field>" }
  • 移除多个字段,可以指定一个要移除字段名的数组:
{ $unset: [ "<field1>", "<field2>", ... ] }

用法

u n s e t 和 unset和 unsetproject

对于移除字段,$unset相当于是$project的别名:

{ $project: { "<field1>": 0, "<field2>": 0, ... } }

内嵌字段

要移除或排除内嵌文档的字段,可以使用点号:

{ $unset: "<field.nestedfield>" }

或:

{ $unset: [ "<field1.nestedfield>", ...] }

举例

使用下面的命令创建books集合:

db.books.insertMany([{ "_id" : 1, title: "Antelope Antics", isbn: "0001122223334", author: { last:"An", first: "Auntie" }, copies: [ { warehouse: "A", qty: 5 }, { warehouse: "B", qty: 15 } ] },{ "_id" : 2, title: "Bees Babble", isbn: "999999999333", author: { last:"Bumble", first: "Bee" }, copies: [ { warehouse: "A", qty: 2 }, { warehouse: "B", qty: 5 } ] }
])

移除一个字段

下面的例子移除顶层字段copies

db.books.aggregate([ { $unset: "copies" } ])

也可以使用下面的方法:

db.books.aggregate([ { $unset: [ "copies" ] } ])

这些操作返回下面的文档:

{ "_id" : 1, "title" : "Antelope Antics", "isbn" : "0001122223334", "author" : { "last" : "An", "first" : "Auntie" } }
{ "_id" : 2, "title" : "Bees Babble", "isbn" : "999999999333", "author" : { "last" : "Bumble", "first" : "Bee" } }

移除顶层字段

下面的例子移除顶层字段isbncopies

db.books.aggregate([{ $unset: [ "isbn", "copies" ] }
])

$unset操作的结果为:

{ "_id" : 1, "title" : "Antelope Antics", "author" : { "last" : "An", "first" : "Auntie" } }
{ "_id" : 2, "title" : "Bees Babble", "author" : { "last" : "Bumble", "first" : "Bee" } }

移除内嵌字段

下面的例子移除等层字段isbn、内嵌字段firstname文档内的)以及内嵌字段warehouse(copies字段数组的元素):

db.books.aggregate([{ $unset: [ "isbn", "author.first", "copies.warehouse" ] }
])

$unset操作的结果为:

{ "_id" : 1, "title" : "Antelope Antics", "author" : { "last" : "An" }, "copies" : [ { "qty" : 5 }, { "qty" : 15 } ] }
{ "_id" : 2, "title" : "Bees Babble", "author" : { "last" : "Bumble" }, "copies" : [ { "qty" : 2 }, { "qty" : 5 } ] }
http://www.lryc.cn/news/299058.html

相关文章:

  • DS Wannabe之5-AM Project: DS 30day int prep day14
  • 【程序设计竞赛】C++与Java的细节优化
  • Java缓冲流——效率提升深度解析
  • 16 亚稳态原理和解决方案
  • C# OCR识别图片中的文字
  • 使用python-numpy实现一个简单神经网络
  • CSS定位装饰
  • java之jvm详解
  • vue3学习——集成sass
  • 开关电源学习之Boost电路
  • QRegExp的学习
  • 28.Stream流
  • 大数据应用对企业的价值
  • 【51单片机】LED点阵屏(江科大)
  • Microsoft OneNote 图片文字提取
  • Linux系统安全——iptables相关总结
  • 深度学习(14)--x.view()详解
  • 最新wordpress外贸主题
  • Spring Cloud Gateway:使用RestController动态更新路由
  • 用Python动态展示排序算法
  • vscode代码快捷键
  • 深入了解C++:形参、内联、重载、引用、const和指针、new和delete
  • Linux 目录结构结构
  • C++基础入门:掌握核心概念(超全!)
  • Linux第47步_安装支持linux的第三方库和mkimage工具
  • 数据工程工程师学习路线图
  • MySQL主从同步与分库分表
  • 百度PaddleOCR字符识别推理部署(C++)
  • C++ Qt框架开发 | 基于Qt框架开发实时成绩显示排序系统(2)折线图显示
  • Microsoft Excel 加载数据分析工具