Mongodb聚合操作中的$unset

学习mongodb,体会mongodb的每一个使用细节,欢迎阅读威赞的文章。这是威赞发布的第62篇mongodb技术文章,欢迎浏览本专栏威赞发布的其他文章。

提到unset, 首先想到的是update操作中,使用unset删除冗余字段。而在聚合操作中的unset与UPDATE中的有什么不同, 通过本篇文档的描述就可以搞清楚。

定义

在聚合操作中,排除一些字段的返回。聚合操作中的$unset并没有对数据产生影响,而只是在返回结果中将不需要的字段排除。

语法

聚合操作中,在返回结果中排除单个字段

{$unset: "<field>"}

向$unset方法传入数组,在返回结果中排除多个字段

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

unset是投射操作project中排除字段的另外一种实现方法

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

在嵌套文档中,使用点操作符定义需要排除的字段。

复制代码
{$unset: "<field.nestedfield>"} 
{$unset: ["<field.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 } ] }
    ])

在聚合操作中,排除一个字段

复制代码
db.books.aggregate([{$unset: "copies"}])
db.books.aggregate([{$unset: ["copies"]}])

排除多个字段

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

排除嵌套文档中的字段

复制代码
db.books.aggregate([{$unset: ["isbn", "author.first", "copies.warehouse"]}])
相关推荐
Boop_wu5 小时前
[Java EE] 多线程编程进阶
java·数据库·java-ee
深瞳智检5 小时前
学习应用 第001期-Windows 10 用 CMD 安装 MySQL 全流程解析(免安装版)
数据库·windows·mysql·压缩包·环境安装
正在走向自律5 小时前
金仓数据库在发电行业的创新应用与实战案例
数据库·国产数据库·电力·kingbasees·电科金仓
华纳云IDC服务商5 小时前
MySQL数据库如何防止SQL注入攻击
数据库·sql·mysql
合作小小程序员小小店5 小时前
桌面开发,在线%物品代送,代接管理%系统,基于vs2022,c#,winform,sql server数据。
开发语言·数据库·sql·microsoft·c#
疏狂难除6 小时前
尝试rust与python的混合编程(二)
数据库·python·rust
小光学长6 小时前
基于微信小程序的家具商城系统g80l9675(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·微信小程序·小程序
j***82706 小时前
Mybatis控制台打印SQL执行信息(执行方法、执行SQL、执行时间)
数据库·sql·mybatis
g***26796 小时前
5、使用 pgAdmin4 图形化创建和管理 PostgreSQL 数据库
数据库·postgresql