MongoDB 类replace替换字符串指定内容

news2024/9/21 15:33:16

目录

需求介绍

技术分析

技术积累

1、replaceOne 语法

2、javascript语法

实战演示

1、查询满足条件的数据

2、在mongodb语法中融入javascript语法并执行

3、查看刚刚被修改的数据


需求介绍

根据业务发展,现在需要对已经存在的数据进行处理,需要替换掉字段中指定字符串。

目的数据结构为:

{

"_id" : ObjectId("6166fa27de458266eecdb288"),

"receiverId" : NumberLong(1011500013127618),

"senderId" : NumberLong(1011500000008954),

"companyId" : 1.0,

"status" : 1.0,

"dataSources" : 4.0,

"senderType" : "employee",

"receiverType" : "customer",

"mediaType" : "text",

"connectMode" : "sys_follow",

"messageType" : "conversation",

"businessId" : NumberLong(1011500013127618),

"createTime" : ISODate("2020-01-21T04:01:23.000Z"),

"updateTime" : ISODate("2020-01-21T04:01:23.000Z"),

"message" : "1.资产京东:无\r\n2.工作京东:现金\r\n3.贷款用途:\r\n4.需要金额和时间:\r\n5.推荐产品:\r\n6.报费京东:\r\n7.征信负债:\r\n8.不签约原因:",

"_class" : "com.ysjr.base.domain.entity.ConversationInfo",

"followId" : NumberLong(1011500031014664),

"followType" : "FW001",

"result" : 1,

"intention" : "FI006",

"loseOrderReason" : [

"LR003"

],

"exec" : 1.0

}

需要将跟进数据的 message 字段中的 ”京东“ 字段替换为 ”其他“。

技术分析

分析发现在MYSQL等关系数据库中有replace函数,对字符串中的字符进行替换。对于mongodb经查询官方文档,发现也有相似的语法可以实现替换功能。如下所示:

1、$replaceOne 语法,但是每次只能更新字符串中发现的第一个目的串

2、javascript语法,在mongodb语法中写js代码来替换字符串,该种方式可以兼容多个目的串的情况,缺点是执行效率慢

3、java代码,java代码直接获取字符串进行replaceAll() 函数替换 ,缺点是需要写代码并且执行效率慢。

综合以上实现方式,结合实际需求,我们本次数据处理选择第二种方式 javascript 语法集合mongodb语法实现。虽然执行效率慢,但是如果采用第一种我们需要执行多次,第三种需要写代码。对于一个一次性处理数据的需求,采用简单有效且仅损失部分性能我们是可以接受的。

技术积累

1、replaceOne 语法

db.getCollection('集合名称')
.updateMany( {},//查询条件 
[{ $set: {"字段名称": { $replaceOne: { input:"字段名称", find:"需要替换的字符", replacement:"目的字符" }//替换语法
 }} }] );

2、javascript语法

db.getCollection('集合名称') 
.find({})//查询条件 
.forEach(//循环获取目标数据 
function(item) { 
var message = item['字符名称']; 
message = message.replace(/需要替换的字符/g, '目的字符');//目标字符串替换,/g 标识全局变量直接解决raplaceAll不支持方案,可以替换多个串 
db.getCollection('集合名称').updateOne({"_id":item['_id']},{$set:{"字段名称":message,"exec":1}});//修改目标字段,完成替换 
});

实战演示

将所有跟进数据的 message 字段中的 ”京东“ 字段替换为 ”其他“

我们直接在测试环境用第二种示范:

1、查询满足条件的数据

db.getCollection('conversation_info') 
.find({"connectMode":"sys_follow","message":{$regex:"京东",$options:"$i"}})

 如图所示有在测试环境数据库中有两条,其中一条目标字段中有多个目的字符串。

2、在mongodb语法中融入javascript语法并执行

db.getCollection('conversation_info') 
.find({"connectMode":"sys_follow","message":{$regex:"京东",$options:"$i"}}) 
.forEach( function(item) { 
var message = item['message']; 
message = message.replace(/京东/g, '其他'); db.getCollection('conversation_info').updateOne({"_id":item['_id']},{$set:{"message":message,"exec":1}}); 
});

 如图所示执行完成,提示成功但语法效率较低。

3、查看刚刚被修改的数据

db.getCollection('conversation_info') 
.find({"connectMode":"sys_follow","message":{$regex:"其他",$options:"$i"}})

 如图所示,发现全部替换为目标字符串,测试完成。

总结:MongoDB 类replace替换字符串指定内容,replaceOne 语法仅能够替换目标字段中第一次出现的字符串,如果出现多次需要多次执行 replaceOne 语法;如果用javascript 语法可以完全兼容多个目标字符替换,极大的方便我们处理数据。

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

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

相关文章

在线安装ESP32和ESP8266 Arduino开发环境

esp32和esp8266都是乐鑫科技开发的单片机产品,esp8266价格便宜开发板只需要十多块钱就可以买到,而esp32是esp8266的升级版本,比esp8266的功能和性能更强大,开发板价格大约二十多元就可以买到。 使用Arduino开发esp32和esp8266需要…

并发replace操作导致的死锁问题

背景 批量对一张表进行replace into操作,每个SQL操作1000条数据,最近有同事反馈使用并发replace操作的时候,遇到了死锁的问题。针对这个问题,我看了看表的结构,发现表中有一个主键,一个唯一索引&#xff0c…

【深度学习环境】Docker

1. Docker 相关安装配置 1.1 docker 安装 参考:https://www.runoob.com/docker/ubuntu-docker-install.html 1.2 nvidia-docker 安装 参考:https://zhuanlan.zhihu.com/p/37519492 1.3 代理加速 参考:https://yeasy.gitbook.io/docker_…

Java学习之路001——基础语法以及IDEA的基础使用

【说明】以下内容,选取于网上搜索进行的排版。如有冲突,请联系作者删除。 一、第一个Hello World程序 1.1 开发工具介绍 eclipse IntelliJ IDEA 1.2 案例开发步骤 首先定义一个类class 类名 在类定义后加上一对大括号{} 在大括号中间添加一个主(ma…

别克GL8改装完工,一起来看看效果

①豪华商务头等舱 别克GL8作为商务车,不管是家用还是商务接待,原车内饰都太掉档次了,所以车主要求全部换掉。>>织布座椅换成航空座椅 主副驾:改装纳帕皮 中排:改装水晶宝座豪华版航空座椅,带通风、加…

Dataway 让 Spring Boot 不再需要 Controller、Service、DAO、Mapper 简单接口直接开发。

新的sql语法可以先看一下官网&#xff0c;部署起来之后会用到Dataql&#xff1a; DataQL - 数据查询语言https://www.dataql.net/先看一下效果 接下来来实现一下。 1 创建spring boot项目 导入依赖 <!--begin dataWay--><!--hasor-spring 负责 Spring 和 Hasor 框架之…

【操作系统】进程管理

进程与线程 1. 进程 进程是资源分配的基本单位 进程控制块 (Process Control Block, PCB) 描述进程的基本信息和运行状态&#xff0c;所谓的创建进程和撤销进程&#xff0c;都是指对 PCB 的操作。 下图显示了 4 个程序创建了 4 个进程&#xff0c;这 4 个进程可以并发地执行…

实战|掌握Linux内存监视:free命令详解与使用技巧

文章目录前言一. free命令介绍二. 语法格式及常用选项三. 参考案例3.1 查看free相关的信息3.2 以MB的形式显示内存的使用情况3.3 以总和的形式显示内存的使用情况3.4 周期性的查询内存的使用情况3.5 以更人性化的形式来查看内存的结果输出四. free在脚本中的应用总结前言 大家…

LAMP项目部署实战2

部署Discuz!论坛 一、Discuz&#xff01;论坛概述&#xff1a; 1&#xff09;Discuz&#xff01;论坛是基于phpmysql进行开发的一套开源的论坛系统。 2&#xff09;下载源代码&#xff1a; 下载地址&#xff1a;码云DiscuzX: Discuz! X 官方 Git&#xff0c;简体中文 UTF8 版…

2023年,35岁测试工程师只能被“优化裁员”吗?肯定不是····

国内的互联网行业发展较快&#xff0c;所以造成了技术研发类员工工作强度比较大&#xff0c;同时技术的快速更新又需要员工不断的学习新的技术。因此淘汰率也比较高&#xff0c;超过35岁的基层研发类员工&#xff0c;往往因为家庭原因、身体原因&#xff0c;比较难以跟得上工作…

mongo数据备份

目录1. mongo单机安装2. mongo(replica set)部署3. mongodump 与 mongorestore工具使用4.rsync工具使用服务端配置客户端配置客户端推送与拉取文件5. 完整mongo全量备份脚本恢复全量备份数据6. 完整mongo增量备份脚本(基于oplog)恢复增量备份数据7.备份策略1. mongo单机安装 m…

高数:极限的定义

目录 极限的定义&#xff1a; 数列极限的几何意义&#xff1a; 由极限的定义得出的极限的两个结论&#xff1a; ​编辑 极限的第三个结论&#xff1a; 例题 方法1&#xff1a; ​编辑 方法2&#xff1a; ​编辑 方法3&#xff1a; ​编辑 极限的定义&#xff1a; 如何理…

JDK8常用新特性的原理与代码演示

Lambda Lambda 表达式&#xff0c;也可称为闭包&#xff0c;Lambda 允许把函数作为一个方法的参数。 格式 (参数列表) -> {代码块} (parameters) -> expression 或 (parameters) ->{ statements; }前置条件 lambda表达式是一段执行某种功能的代码块&#xff0c;需要…

数据结构与算法——4时间复杂度分析2(常见的大O阶)

这篇文章是时间复杂度分析的第二篇。在前一篇文章中&#xff0c;我们从0推导出了为什么要用时间复杂度&#xff0c;时间复杂度如何分析以及时间复杂度的表示三部分内容。这篇文章&#xff0c;是对一些常用的时间复杂度进行一个总结&#xff0c;相当于是一个小结论 1.常见的大O…

ESFP型人格的特征,ESFP型人格的优势和劣势分析

ESFP型人格的特征ESFP&#xff08;表演者型人格&#xff09;是人群中的开心果。他们外向&#xff0c;友善&#xff0c;包容&#xff0c;有他们在的地方总是充满着活泼的氛围。ESFP对于新的朋友&#xff0c;新的环境适应良好&#xff0c;他们是完完全全的社交动物&#xff0c;对…

【数据库原理 | MySQL】一文打通 DDL语句

&#x1f935;‍♂️ 个人主页: 计算机魔术师 &#x1f468;‍&#x1f4bb; 作者简介&#xff1a;CSDN内容合伙人&#xff0c;全栈领域优质创作者。 书接上文介绍了数据库的前世今生&#xff0c;本文讲解SQL语句中的DDL语句 文章目录二、SQL2.1 SQL通用语法2.2 SQL的分类三、 …

I.MX6ULL_Linux_系统篇(19) kernel编译及Makefile分析

Linux 内核 Linux 由 Linux 基金会管理与发布&#xff0c; Linux 官网为 https://www.kernel.org&#xff0c;所以你想获取最新的Linux 版本就可以在这个网站上下载&#xff0c;网站界面如图所示&#xff1a; 从图中可以看出最新的稳定版 Linux 已经到了 6.2&#xff0c;NXP …

Python常用标准库-sys库一文详解

目录 前言 一、Sys库概述 二、Sys查看版本信息 1.sys.version获取Python版本信息 2.sys.api_version获取解释器中C的API版本 3.sys.getwindowsversion系统功能版本 4.sys.hexversion()获取Python解释器的版本值 5.sys.implementation获取当前正在运行的Python解释器的实现…

Redis源码---如何实现一个性能优异的Hash表

目录 前言 Redis 如何实现链式哈希&#xff1f; 什么是哈希冲突&#xff1f; 链式哈希如何设计与实现&#xff1f; Redis 如何实现 rehash&#xff1f; 什么时候触发 rehash&#xff1f; rehash 扩容扩多大&#xff1f; 渐进式 rehash 如何实现&#xff1f; 前言 Hash …

数据处理 |遍历所有文件夹及子目录文件夹方法总结与实例代码详解

深度学习中不可避免的数据预处理~1. glob.glob()方法 2. pathlib中的Path方法3. os.walk()方法1. glob.glob()方法 语法glob.glob(pathname)&#xff08;多指定文件类型&#xff0c;查找jpg,png,txt,json等&#xff09;缺点&#xff1a;查找文件较慢2. 路径操作库pathlib中的Pa…