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"]}])
相关推荐
对着晚风做鬼脸5 分钟前
MySQL进阶知识点(六)---- 存储引擎
数据库·mysql
百锦再14 分钟前
从 .NET 到 Java 的转型指南:详细学习路线与实践建议
android·java·前端·数据库·学习·.net·数据库架构
卷Java38 分钟前
uni-app 模板语法修复说明
java·数据库·spring boot·uni-app·mybatis
我要用代码向我喜欢的女孩表白1 小时前
HBase全量+增量迁移import/export方式
大数据·数据库·hbase
源码部署21 小时前
Java-尚硅谷_数据库中间件_Mycat教程
数据库
-dcr2 小时前
21.mariadb 数据库
数据库·云计算·运维开发·mariadb
荒村瘦马2 小时前
MySQL中SELECT 语句如何 INTO OUTFILE 保存数据到文件
数据库·mysql·导出文件·into outfile
Script kid2 小时前
Pytest框架速成
数据库·pytest
hans汉斯3 小时前
【人工智能与机器人研究】一种库坝系统水下成像探查有缆机器人系统设计模式
大数据·数据库·论文阅读·人工智能·设计模式·机器人·论文笔记
June`3 小时前
Redis:高性能内存数据库的六大核心优势
数据库·redis·缓存