Mongodb中字段的删除

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

本篇文章,探讨UPDATE中的操作符unset。Mongodb数据插入后,开发人员使用unset方法,将冗余的字段删除 。

定义

在UPDATE操作中,使用$unset删除指定字段。注意区分聚合操作中的unset。 在UPDATE中,unset使文档的结构发生变化,会删除文档中的指定字段。而在聚合操作中使用unset,影响的只是投射结果,在返回结果中排除了指定的字段,而不会删除文档中的字段。

语法

复制代码
{$unset:  {<field1>:"", ...}}

其中<field1>后指定的值,不会对字段删除产生影响。删除嵌套文档或数组中的字段时,使用点操作符。

行为

  • 自mongodb5.0开始,UPDATE操作按照字段名称的字典顺序更新字段。当字段中包含数字时,按照数字顺序依次更新字段。当然,对一个文档的多个字段操作,是原子性的。
  • mongodb 5.0版本以后,向$unset传入空表达式({ })时,mongodb不再抛出错误。空表达式不会修改字段值 ,也不会在oplog中,添加新的操作记录。
  • 当指定删除的字段在文档中不存在时,$unset操作无效,不会对数据产生影响。
  • 当使用去匹配数组元素时, unset使用null替换匹配的数组元素而不是删除数组元素。这种行为保证数组大小和数组元素的位置。

应用

创建集合products并插入数据

复制代码
db.products.insertMany([
     { "item": "chisel", "sku": "C001", "quantity": 4, "instock": true },
     { "item": "hammer", "sku": "unknown", "quantity": 3, "instock": true },
     { "item": "nails", "sku": "unknown", "quantity": 100, "instock": true }
    ])

删除匹配查询条件{sku: "unknown"}的第一条数据中的字段quantity, instock.

复制代码
db.products.updateOne({
    sku: "unknown"
}, {
    $unset: {quantity: "", instock:""}
})
相关推荐
sinat_383437361 小时前
Laravel 8 中实现错误日志与调试日志分离的完整配置指南
jvm·数据库·python
sunshine8859 小时前
财务RPA的深水区应用:超越自动化,迈向智能决策支持
数据库
efir OONA10 小时前
MySQL数据库误删恢复_mysql 数据 误删
数据库·mysql·adb
zhangchaoxies10 小时前
如何在 Go 中安全复制接口指针所指向的值
jvm·数据库·python
陈陈CHENCHEN11 小时前
【数据库】MySQL 8.0.40 至 8.0.44 RPM 方式升级指南
数据库·mysql
m0_7349497911 小时前
怎么利用Navicat进行调整备份文件压缩等级_详细配置与操作步骤
jvm·数据库·python
T.i.s11 小时前
番外续2-MIT-BIH Arrhythmia Database
数据库
有味道的男人12 小时前
AI 效率翻倍:对接 1688 拍立淘接口,商品全量信息一键抓取
数据库
m0_7411733312 小时前
如何处理SQL中的NULL值_使用ISNULL或COALESCE函数
jvm·数据库·python
志栋智能12 小时前
超自动化巡检:解锁运维数据的深层价值
运维·服务器·数据库·自动化