MongoDB $rename 给字段一次重新命名的机会

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

在日常编写程序过程中,命名错误是经常出现的错误。拼写错误的单词,大小写字母的错误等。还有另外一种场景,一些字段定义在文档的顶层,而随着项目的进展,开发人员期望将字段移动到文档的嵌套文档当中。

Mongodb的$rename方法,为开发人员提供了字段名称修改的便利。同时该方法也支持嵌套文档字段的移动。

定义

操作符$rename修改字段的名称

语法

{ $rename: {<field1>: <newName1>, <field2>: <newName2>, ...}}

其中,新的字段名称必须与已有字段不同。

在下面的更新语句中,将字段名称nickname更新为字段 alias, 同时将字段cell更新为mobile

db.students.updateOne({_id: 1}, {$rename: {'nickname': 'alias', 'cell': 'mobile'}}
)

行为

当在UPDATE中使用$rename操作时,Mongodb完成了下面的行为

  • 使用$unset删除带有原来字段名称的字段和新字段名称的字段。
  • 执行$set操作,将字段值和新字段名称添加到文档中。

使用$rename时,对每个文档的操作是原子操作。$rename操作可能不会保留文档中字段排序。支持将字段从嵌套文档中搬入搬出。但不支持文档数组中字段的搬入和搬出。

当文档中存在与新字段名称相同的字段时,文档中已有同名字段会被删除。

重命名文档中不存在的字段时,使用$rename操作不会对文档进行更新。

mongodb 5.0版本以后,向$rename传入空表达式({ })时,mongodb不再抛出错误。空表达式不会修改字段值 ,也不会在oplog中,添加新的操作记录。

应用

构建测试集合students并插入数据。能够看到,插入集合中字段名称"nmae"输入错误。

db.students.insertMany([{"_id": 1, "alias": ["The American Cincinnatus", "The American Fabius"],"mobile": "555-555-5555","nmae": { "first": "george","last": "washington"}}, {"_id": 2, "alias": ["My dearest friend"],"mobile": "222-222-2222","nmae": { "first": "abigail","last": "adams"}}, {"_id": 3, "alias": ["Amazing grace"],"mobile": "111-111-1111","nmae": { "first": "grace","last": "hopper"}}])

构建数据更新语句,修改字段名称。

db.students.updateMany({"nmae": {$ne: null}},{$rename: {"nmae": "name"}})  

构建另外一个UPDATE语句,修改嵌套文档中的名称。

db.students.updateOne({_id: 1},{ $rename: {"name.first": "name.fname"}})   

修改一个不存在的字段名称。返回结果中修改文档数量为0

db.students.updateOne({_id: 1}, {$rename: {'wife': 'spouse'}})    
{"acknowledged" : true,"matchedCount" : 1,"modifiedCount" : 0
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/22450.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

gitbook 域名设置 域名绑定 自定义域名

有时候我们搜文档的时候&#xff0c;会遇到gitbook的文档。诸如这样&#xff1a; jums.gitbook.io/mysql-shi-zhan-45-jiang 即&#xff1a;个人的名字gitbook的域名书名。 具体格式如下&#xff1a; 1. 自定义域名 所有在 Gitbook.com 上的书的http 地址为 http://{author…

什么是人机协同翻译

什么是人机协同翻译 序什么是人机协同翻译账号绑定服务开通文档翻译图片翻译体验感受及建议 序 什么是人机协同翻译&#xff0c;为什么会需要人机协同翻译&#xff0c;以及人机协同翻译的效果&#xff0c;应用场景等&#xff0c;本文将关于这些内容一一解答。 什么是人机协同…

大语言模型RAG-将本地大模型封装为langchain的chat model(三)

大语言模型RAG-将本地大模型封装为langchain的chat model&#xff08;三&#xff09; 往期文章&#xff1a; 大语言模型RAG-技术概览 (一) 大语言模型RAG-langchain models (二) 上一期langchain还在0.1时代&#xff0c;这期使用的langchain v0.2已经与之前不兼容了。 本期介…

【调试笔记-20240604-Linux-为 OpenWrt LuCI 界面添加多语言支持】

调试笔记-系列文章目录 调试笔记-20240604-Linux-为 OpenWrt LuCI 界面添加多语言支持 文章目录 调试笔记-系列文章目录调试笔记-20240604-Linux-为 OpenWrt LuCI 界面添加多语言支持 前言一、调试环境操作系统&#xff1a;Ubuntu 22.04.4 LTS编译环境调试目标 二、调试步骤预…

mysql使用sorce、load 导入数据

1、本机安装mysql https://blog.csdn.net/weixin_52687711/article/details/130509902 注意&#xff1a;修改安装路径 配置环境变量 2. 使用sorce命令导入数据 https://blog.csdn.net/2301_82257317/article/details/138332048 使用mysql命令框链接目标数据库 以管理员身份运…

新媒体运营主要都做哪些内容的工作?

1.新媒体运营的核心工作是转化。这包括通过活动运营、内容运营和社群运营等方式吸引和激活用户&#xff0c;从而增加产品的活跃度和留存率。具体来说&#xff0c;运营人员会撰写内容并发布到各大自媒体平台&#xff0c;以吸引和拉新用户。同时&#xff0c;他们还会通过各种手段…

游戏资源汇总

游戏平台资源汇总 668 游戏仓库 网站名称&#xff1a;668 游戏仓库网址&#xff1a;668 游戏仓库介绍&#xff1a;全球最大的游戏下载中心、游戏交流中心&#xff0c;提供单机游戏、Switch 游戏、PS4 游戏等资源。 PC 游戏下载 网站名称&#xff1a;PC 游戏下载网址&#x…

图像关键特征描述方法-小目标

图像关键特征描述方法主要包括以下几种: SIFT(尺度不变特征变换): SIFT是一种广泛使用的特征描述方法,它通过尺度空间和梯度方向直方图来描述图像中的关键点。SIFT特征描述具有尺度不变性和旋转不变性,对于光照和视角变化也具有一定的鲁棒性。 SURF(加速稳健特征): SURF…

Echarts柱状图数据太多,自定义长度之后,自适应浏览器缩放

不知道是不是最优解&#xff0c;但是当前解决了我遇到的问题&#xff0c;如有更好的方法&#xff0c;希望看到这篇文章的同学可以不吝指导一番&#xff0c;非常感谢 1、问题描述&#xff1a; 因Ecahrts柱状图数据有时多有时少&#xff0c;所以在数据达到一定程度之后&#xff…

第54期|GPTSecurity周报

GPTSecurity是一个涵盖了前沿学术研究和实践经验分享的社区&#xff0c;集成了生成预训练Transformer&#xff08;GPT&#xff09;、人工智能生成内容&#xff08;AIGC&#xff09;以及大语言模型&#xff08;LLM&#xff09;等安全领域应用的知识。在这里&#xff0c;您可以找…

Spring Boot 实现动态数据源配置

前言 之前在CSDN博客以及某站看了教程&#xff0c;不免觉得有点不知如何下手&#xff0c;好在最后融合了以下&#xff0c;得出了一个比较简单的配置动态数据源的过程。 首先项目是Spring Boot的单体项目&#xff0c;我们的需求是要连接多个数据库&#xff0c;那么就需要配置多个…

产品经理:做好有效的客户需求分析

需求分析是产品开发过程中的重要环节&#xff0c;它直接决定了产品是否能够满足市场需求和用户期望。通过深入了解客户需求&#xff0c;产品经理可以确保产品功能的设计符合用户的实际需求&#xff0c;从而提高产品的用户满意度和市场竞争力。 一、识别用户需求 识别用户需求…

目标检测数据集 - 海洋垃圾检测数据集下载「包含VOC、COCO、YOLO三种格式」

数据集介绍&#xff1a;海洋垃圾检测数据集&#xff0c;真实拍摄海洋海底场景高质量垃圾检测图片数据&#xff0c;涉及场景丰富&#xff0c;比如海底塑料垃圾数据、海底铁制品罐状垃圾数据、海底纸张垃圾数据、海洋生物和海底垃圾同框数据、海底探索仪器和海底垃圾同框数据、海…

【ArcGIS微课1000例】0114:基于DEM地形数据整体抬升或下降高程

相关阅读:【GlobalMapper精品教程】083:基于DEM整体抬升或下降地形高程的两种方式 文章目录 一、任务分析二、栅格计算器简介三、地形整体修改四、注意事项一、任务分析 打开软件,加载配套实验数据中的0112.rar中的dem数据,如下所示,dem的高程范围为256.75~342.37米,现在…

用PlantUML描绘C++世界:通过文本描述精准控制UML图的生成

往期本博主的 C 精讲优质博文可通过这篇导航进行查找&#xff1a; Lemo 的C精华博文导航&#xff1a;进阶、精讲、设计模式文章全收录 前言 在编写程序时&#xff0c;可视化的工具可以极大地帮助我们理解和设计复杂的系统。对于C程序员来说&#xff0c;一个强大的工具是UML&am…

Flutter 中的 RawImage 小部件:全面指南

Flutter 中的 RawImage 小部件&#xff1a;全面指南 Flutter 是一个流行的跨平台 UI 框架&#xff0c;由 Google 开发&#xff0c;它允许开发者使用 Dart 语言构建高性能、美观的应用。在 Flutter 的丰富组件库中&#xff0c;RawImage 是一个低级的图像组件&#xff0c;它允许…

[JS]学习笔记1 -- JAVAScript输入输出+变量

目录 1、组成&#xff1a; 2、书写位置&#xff1a; 2.1 内联JAVAScript&#xff1a; 2.2 内部JAVAScript&#xff1a; 2.3 外部JAVAScript&#xff1a; 3、注释 3.1 单行注释&#xff1a; 3.2 块注释&#xff1a; 4、输入输出语法 4.1 输入&#xff1a; 4.2 输出&a…

怎么用微信小程序实现远程控制空调

怎么用微信小程序实现远程控制空调呢&#xff1f; 本文描述了使用微信小程序调用HTTP接口&#xff0c;实现控制空调&#xff0c;通过不同规格的通断器&#xff0c;来控制不同功率的空调的电源。 可选用产品&#xff1a;可根据实际场景需求&#xff0c;选择对应的规格 序号设备…

最大似然参数估计、贝叶斯参数估计、最小二乘估计与贝叶斯学习的本质区别

最大似然参数估计和贝叶斯参数估计的区别在于最大似然估计认为参数是确定性的量&#xff0c;而贝叶斯估计认为参数是随机变量。之所以命名贝叶斯估计是因为用到了贝叶斯公式。根据贝叶斯公式&#xff0c;从先验概率密度转换到后验概率密度。 统计学中的贝叶斯参数估计是&#x…

python创建项目时关于new conda environment的解释

“New Conda Environment” 指的是创建一个新的 Conda 环境。Conda 是一个开源的跨平台包管理和环境管理系统&#xff0c;它可以帮助用户方便地安装、运行和升级软件包及其依赖关系。特别适用于数据科学、机器学习等领域&#xff0c;因为它对Python及非Python的包管理都有很好的…