MongoDB修改文档

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
简介: MongoDB修改文档 一、文档替换     文档替换其实在之前已经有讲过了,就是传入两个对象,第一个对象作为调节,第二个条件作为满足条件的文档修改的内容,例如:     db.test.

MongoDB修改文档

一、文档替换

    文档替换其实在之前已经有讲过了,就是传入两个对象,第一个对象作为调节,第二个条件作为满足条件的文档修改的内容,例如:

    db.test.update({"name":"kevin-01"} , {"name": "kevin"});   # 修改  前面条件为,后面为修改的属性和值

 

二、修改器进行修改

    文档提交比较好理解,而修改器是在后面一个文档为对象的基础上,将对象的根key作为修改器类型,后面的对象为真正修改操作的对象,如: {"$set"{} }

1、$set $unset

    db.test.update({"name":"kevin-01", {"$set":{"age":NumberInt("18")}}}); # 满足条件:修改年龄字段,没有年龄字段则进行添加

    db.test.update({"name":"kevin-01"},{"$unset":{"age": }});               # 满足条件:删除age字段

2、$inc(减少值可以用负数)

    db.test.update("name":"kevin-01",{"$inc":{"age": 5}});  # 满足条件,年龄加5岁(负数表示减去

3、$push ($each、$slice、 $sort)

    1)、 往数组对象中添加一个元素

    db.test.update({"name":"kevin-01"},{"$push":{"comments":{"id":"1","content":"content-01"}}});

 

    2)、往数组中添加多个元素,使用$each

    commentsArr = [{"id":NumberInt("2","content":"content-02")},{"id":NumberInt("3","content":"content-03")}];

    db.test.update("name":"kevin-01",{"$push":{"$each": commentsArr }});

    3)、往数组中添加多个元素,并进行排序($sort,值为1表示正序,-1反之),只保留最近的多少个元素($slice,值只能为负数)

    commentsArr = [{"id":NumberInt("2","content":"content-02")},{"id":NumberInt("3","content":"content-03")}];

    db.test.update(user, {"$push":{"comments":
           {"$each":[{"id":NumberInt("2"),"content":"content-02"},{"id":NumberInt("3"),"content":"content-03"}],
            "$slice":-2,
            "$sort":{"id":-1}

    }}});

4、$addToSet

    往数组中添加的数据,为了保证不重复,则可以使用$addToSet,并且可以配置$each进行使用,就想配合$push一样:

    db.test.update({"name":"kevin-01"},{"$addToSet":{"email":"kevin-01@163.com"}});

    db.test.update({"name":"kevin-01"},{"$addToSet":{"email":{"$each":["kevin-01@163.com","kevin-02@163.com"]}}});

5、$pop、$pull

    1)、从数组的尾部或者头部删除一个元素, 1表示重尾部删除,-1表示从头部删除

    db.test.update({"name":"kevin-01"},{"$pop":{"email":1}});

    2)、从数组中删除满足条件的元素

    db.test.update({"name":"kevin-01"},{"$pull":{"email":"kevin-01@163.com"}});

三、upsert(添加或更新文档)

    1)、upinsert

    # 更新的时候,第一个对象为条件,第二个对象为修改的内容,第三个为true,表示新增或修改

    db.test.update({"name":"kevin-01"},{"classNo":NumberInt("5")},true); 

    2)、$setOnInsert

    # 只保证文档在插入时生效,修改时候则保持不变,如创建时间(createdAt)字段,这也是阿里手册规范

    db.test.update({"name":"kevin-01",{"$setOnInsert":{"createdAt":new Date()}}, true});

    3)、save(方便操作,直接见下图)

三、更新多个文档

    update的第一个参数对象为条件,第二个参数对象为更新的对象,第三个为是否upinsert,第四个为是否修改所有满足条件的所有文档,默认关闭,只修改满足条件的第一条

    db.test.update({条件},{修改},false, true);

原文地址 https://blog.csdn.net/it_lihongmin/article/details/81410707
相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。   相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
相关文章
|
2月前
|
NoSQL MongoDB 数据库
MongoDB 更新文档
10月更文挑战第14天
59 2
|
2月前
|
存储 NoSQL MongoDB
数据的存储--MongoDB文档存储(二)
数据的存储--MongoDB文档存储(二)
80 2
|
2月前
|
SQL NoSQL MongoDB
MongoDB 查询文档
10月更文挑战第15天
36 1
|
2月前
|
存储 NoSQL 关系型数据库
数据的存储--MongoDB文档存储(一)
数据的存储--MongoDB文档存储(一)
109 3
|
2月前
|
NoSQL MongoDB
MongoDB 删除文档
10月更文挑战第15天
52 0
|
2月前
|
存储 JSON NoSQL
MongoDB 插入文档
10月更文挑战第14天
39 0
|
3月前
|
SQL NoSQL Shell
03 MongoDB文档的各种增加、更新、删除操作总结
文章总结了MongoDB中文档的增删改操作,包括插入文档、更新现有文档以及删除文档的具体方法和示例。
146 0
|
7月前
|
存储 NoSQL 数据管理
【MongoDB 专栏】MongoDB 文档模型详解
【5月更文挑战第10天】MongoDB 是一种流行的 NoSQL 数据库,以其灵活的文档数据模型著称。文章介绍了文档的基本概念、结构及操作,包括插入、查询、更新和删除。文档特点是灵活且可扩展,适合存储不同结构的数据。优势在于简化数据建模、提升开发效率并适应动态数据。应用场景包括用户信息、日志记录和电商数据管理。但需注意数据一致性和文档大小对性能的影响。理解文档模型有助于高效利用 MongoDB。
101 1
【MongoDB 专栏】MongoDB 文档模型详解
|
5月前
|
存储 NoSQL MongoDB
MongoDB拆分大文档、嵌入文档
【7月更文挑战第6天】
55 0