MongoDB数据修改案例

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
简介:

数据更新操作

队友MongoDB而言,数据更新是一件非常麻烦的事情。Mongo通常会存副本数据,数据有变更的时候,最好的做法是删除MongoDB的数据,重新插入。

Mongo中提供了两个函数,一个是save(),一个是update()。

范例:更新存在的数据 -- 将年龄是19岁的人的成绩都更新为100分

只更新查询出的第一条数据,没有不增加

db.students.update({"age":19},{"$set":{"score":100}},false,false);

所有满足条件的数据都更新

db.students.update({"age":19},{"$set":{"score":100}},false,true);

范例: 更新不存在的数据 -- 将年龄是30岁的人更新他的名称name

db.students.update({"age":30},{"$set":{"name":"小李子"}},true,false);

第一个true表示如果不存在,则创建一条新数据。这种功能用的比较少。

修改器

1.inc 主要针对一个数字字段,增加某个字段的数据内容。

范例:将所有年龄为19岁的学生成绩一律减少30分。

db.students.update({"age":19},{"$inc":{"score":-30,"age":1}},false,true);

2.set 进行内容重新设置

范例:将年龄为20的人的成绩修改为89

sql db.students.update({"age":19},{"$set":{"score":-89}},false,true);

3.unset 删除某个成员的内容

范例:删除张三的年龄和成绩信息

db.students.update({"name":"张三"},{"$unset":{"age":1,"score":1}},false,true);

4.push 相当于将内容追加到指定的成员之中(基本上是用于数组)。一次增加一个元素,如果增加的是数组,表示一次增加一个数组。

范例:向张三添加课程信息

db.students.update({"name":"张三"},{"$push":{"course":["语文","数学"]}},false,true);

如果没有数组,就进行一个新的数组的创建,如果有则进行内容的追加。

5.pushAll与push类似,可以一次追加多个内容到数组里面

db.students.update({"name":"张三"},{"$pushAll":{"course":["美术","音乐"]}},false,true);

6.addToSet 如果已存在就不添加了

db.students.update({"name":"张三"},{"$addToSet":{"course":"美术"}},false,true);

7.pop 删除数组内的数据。文档是行,成员是列,集合是表。-1表示第一个课程。1表示最后一个课程。

db.students.update({"name":"张三"},{"$pop":{"course":-1}});

8.pull 从数组中删除指定内容的数据

db.students.update({"name":"张三"},{"$pull":{"course":"美术"}});

9.pullAll一次性删除多个内容

db.students.update({"name":"张三"},{"$pullAll":{"course":["音乐","舞蹈"]}});

10.rename 为成员名称重命名

db.students.update({"name":"张三"},{"$rename":{"course":"课程"}},false,true);



本文转自TBHacker博客园博客,原文链接:http://www.cnblogs.com/jiqing9006/p/7856800.html,如需转载请自行联系原作者
相关文章
|
10月前
|
存储 NoSQL MongoDB
【赵渝强老师】MongoDB写入数据的过程
在MongoDB数据更新时,WiredTiger存储引擎通过预写日志(Journal)机制先将更新写入日志文件,再通过检查点操作将日志中的操作刷新到数据文件,确保数据持久化和一致性。检查点定期创建,缩短恢复时间,并保证异常终止后可从上一个有效检查点恢复数据。视频讲解及图示详细说明了这一过程。
236 23
【赵渝强老师】MongoDB写入数据的过程
|
存储 NoSQL MongoDB
数据的存储--MongoDB文档存储(二)
数据的存储--MongoDB文档存储(二)
287 2
|
7月前
|
NoSQL MongoDB 数据库
数据库数据恢复——MongoDB数据库服务无法启动的数据恢复案例
MongoDB数据库数据恢复环境: 一台Windows Server操作系统虚拟机上部署MongoDB数据库。 MongoDB数据库故障: 管理员在未关闭MongoDB服务的情况下拷贝数据库文件。将MongoDB数据库文件拷贝到其他分区后,对MongoDB数据库所在原分区进行了格式化操作。格式化完成后将数据库文件拷回原分区,并重新启动MongoDB服务。发现服务无法启动并报错。
|
SQL NoSQL 数据管理
数据管理DMS使用问题之如何批量导入MongoDB的数据文件
阿里云数据管理DMS提供了全面的数据管理、数据库运维、数据安全、数据迁移与同步等功能,助力企业高效、安全地进行数据库管理和运维工作。以下是DMS产品使用合集的详细介绍。
|
8月前
|
存储 JSON NoSQL
微服务——MongoDB的数据模型
MongoDB采用文档(document)作为最小存储单位,类似关系型数据库中的行,使用BSON(Binary-JSON)格式存储数据。BSON是JSON的二进制扩展,支持内嵌文档和数组,新增了如Date、BinData等特殊数据类型,具有轻量、高效、可遍历的特点,适合非结构化与结构化数据存储。其灵活性高,但空间利用率略低。BSON数据类型包括string、integer、boolean等基本类型及date、object id等扩展类型。
205 0
|
9月前
|
存储 NoSQL MongoDB
数据库数据恢复—MongoDB数据库迁移过程中丢失文件的数据恢复案例
某单位一台MongoDB数据库由于业务需求进行了数据迁移,数据库迁移后提示:“Windows无法启动MongoDB服务(位于 本地计算机 上)错误1067:进程意外终止。”
|
NoSQL MongoDB 数据库
使用NimoShake将数据从AWS DynamoDB迁移至阿里云MongoDB
使用NimoShake将数据从AWS DynamoDB迁移至阿里云MongoDB
|
存储 NoSQL 关系型数据库
数据的存储--MongoDB文档存储(一)
数据的存储--MongoDB文档存储(一)
578 3
|
NoSQL MongoDB 数据库
python3操作MongoDB的crud以及聚合案例,代码可直接运行(python经典编程案例)
这篇文章提供了使用Python操作MongoDB数据库进行CRUD(创建、读取、更新、删除)操作的详细代码示例,以及如何执行聚合查询的案例。
244 6
|
NoSQL 安全 MongoDB
【MongoDB深度揭秘】你的更新操作真的安全了吗?MongoDB fsync机制大起底,数据持久化不再是谜!
【8月更文挑战第24天】MongoDB是一款备受欢迎的NoSQL数据库,以其灵活的文档模型和强大的查询能力著称。处理关键业务数据时,数据持久化至关重要。本文深入探讨MongoDB的写入机制,特别是更新操作时的fsync行为。MongoDB先将数据更新至内存以提升性能,而非直接写入磁盘。fsync的作用是确保数据从内存同步到磁盘,但MongoDB并非每次更新后都立即执行fsync。通过设置不同的写入关注级别(如w:0、w:1和w:majority),可以平衡数据持久性和性能。
192 1

推荐镜像

更多