MongoDB-mongoshell脚本订正数组中的某个数组类型的字段的值
创始人
2024-05-31 19:55:18
0

MongoDB是一种面向文档的NoSQL数据库。由于其出色的吞吐量和高可扩展性,越来越多的企业正在将其作为首选的数据存储方案。目前我们就在使用这个数据库。在使用MongoDB时,我们有时候需要使用JavaScript语言的特性来操纵数据库中的数据。其中一个常用的语言特性是 instanceof 操作符。在这篇文章中,我们将探讨如何在MongoDB中使用 instanceof 操作符来检查数据是否为一个数组。

先来描述一下背景:最近在做一个需求的时候,入库的数据如果没有值的话 ,etl层面存成了空字符串,但是下面的测试没有针对这种情况做兼容处理,没有测出来,临时方案就是需要我们上游来订正数据,因此,需要写一个脚本去订正数据,而需要订正的数据在一个数组的字段里面。数据的格式如下:

{"_id" : ObjectId("64004511fdfa1d0111a2d4d3"),"options" : [{"optionType" : 1,"eventDetails" : [{"ratioOld" : "","payoutNumber" : 1,"outturnId" : 12345678,"ratioNew" : ""}],"optionNumber" : 1,"optionDescription" : "this is a test","defaultOptionIndicator" : 1}],"updateTime" : ISODate("2023-03-07T02:45:47.797Z"), "createTime" : ISODate("2023-03-02T06:42:46.282Z"), "auditStatus" : 4 
}

比如针对上面的数据,需要找出eventDetails里面的ratioOld字段,如果是""的,就要转成null,转换脚本如下:

db.表名.find({ "options.eventDetails.ratioOld": "" }).forEach(function (item) {if (item.options instanceof Array) {item.options.forEach(function (option) {if (option.eventDetails instanceof Array) {option.eventDetails.forEach(function (detail) {if (detail.ratioOld == "") {detail.ratioOld = nulldetail.ratioNew = null;}})}})item.updateTime = new Date()db.getCollection('表名').save(item)}
});

以上脚本只是做一个参考,实际运用的时候要根据实际情况再进行调整。

往期推荐

MongoDB-通过docker搭建一个用来练习的mongodb数据库

MongoDB-MongoDB简介

MongoDB-在windows电脑本地安装一个mongodb的数据库

MongoDB-使用mongo/mongosh命令行连接数据库

MongoDB-快速上手MongoDB命令行的一些简单操作

MongoDB-_id字段的含义介绍

MongoDB-插入数据insert、insertOne、insertMany、save用法介绍

MongoDB-表数据查询的基本用法介绍

MongoDB-查询语句中>、>=、<、<=、=、!=、in、not in用法介绍

MongoDB-查询语句中逻辑运算符not、and、or、nor用法介绍

MongoDB-查询语句中$exists以及结合$ne、$nin、$nor、$not使用介绍

MongoDB-使用$type查询某个字段的类型是否为xxx

MongoDB-查询中$all的用法介绍

MeterSphere教程:python2前置脚本查mongodb库提取参数&查库断言

MongoDB-查找表里面重复的记录

MongoDB-怎么将csv数据导入mongodb数据库的某张表中

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...