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

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:""}
})

http://www.lryc.cn/news/366713.html

相关文章:

  • TP8 PHP 动态变量调用 (new $class())->$action($data)
  • 理解JVM内存模型与Java内存模型(JMM)
  • 鸿蒙OS初识
  • 发布自己的 npm 插件包:步骤与最佳实践
  • BubbleML: A Multiphase Multiphysics Dataset and Benchmarks for Machine Learning
  • vscode+latex设置跳转快捷键
  • PHP序列化、反序列化
  • websocket链接携带参数
  • 【C++进阶】深入STL之list:模拟实现深入理解List与迭代器
  • 技术管理之巅—如何从零打造高质效互联网技术团队阅读体验
  • 机器学习与数据挖掘知识点总结(一)
  • 行心科技中禄松波携手,开启智能健康新时代
  • 前端多人项目开发中,如何保证CSS样式不冲突?
  • 【YOLOv10改进[CONV]】使用DualConv二次创新C2f模块实现轻量化 + 含全部代码和详细修改方式 + 手撕结构图 + 全网首发
  • 基于SSM+Jsp的高校信息资源共享平台
  • 软件测试--Linux快速入门
  • module ‘django_cas_ng.views‘ has no attribute ‘login‘
  • CW32F030K8T7单片机在即热式热水器的应用介绍
  • HTML静态网页成品作业(HTML+CSS)—— 美食湘菜介绍网页(5个页面)
  • 使用redis构建简单的社交网站
  • 【Java面试】九、微服务篇-SpringCloud(上)
  • Python 树状数组
  • 【QEMU中文手册】2.2 调用方式(持续更新中)
  • (函数)判断一句话中最长的单词(C语言)
  • QT5.5.0中使用lambda表达式时遇到的问题
  • 【Go语言精进之路】构建高效Go程序:了解切片实现原理并高效使用
  • Python与C语言:深入探索两者的奥秘与差异
  • 图像编解码器在AI绘画中的革新作用
  • SecureCRT[po破] for Mac SSH终端操作工具[解] 安装教程
  • 【大数据架构】基于流式数据的大数据架构升级