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"]}])
相关推荐
夜泉_ly2 小时前
MySQL -安装与初识
数据库·mysql
qq_529835353 小时前
对计算机中缓存的理解和使用Redis作为缓存
数据库·redis·缓存
月光水岸New5 小时前
Ubuntu 中建的mysql数据库使用Navicat for MySQL连接不上
数据库·mysql·ubuntu
狄加山6755 小时前
数据库基础1
数据库
我爱松子鱼5 小时前
mysql之规则优化器RBO
数据库·mysql
chengooooooo6 小时前
苍穹外卖day8 地址上传 用户下单 订单支付
java·服务器·数据库
Rverdoser7 小时前
【SQL】多表查询案例
数据库·sql
Galeoto7 小时前
how to export a table in sqlite, and import into another
数据库·sqlite
人间打气筒(Ada)7 小时前
MySQL主从架构
服务器·数据库·mysql
leegong231117 小时前
学习PostgreSQL专家认证
数据库·学习·postgresql