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数据库的某张表中

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...