iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >monggodb学习过程--update
  • 794
分享到

monggodb学习过程--update

2024-04-02 19:04:59 794人浏览 八月长安
摘要

今天看书看到mongoDB权威指南这本书对update这一篇进行了详细详解,因为知识点有点多,所以博客记录一下,如果只是看我觉得明天就忘了。更新文档有两种方式:1,文档替换  2,修改器替换(只是

今天看书看到mongoDB权威指南这本书对update这一篇进行了详细详解,因为知识点有点多,所以博客记录一下,如果只是看我觉得明天就忘了。

更新文档有两种方式:

1,文档替换  2,修改器替换(只是修改单个字段的内容)

关于update有哪些参数可以看一下帮助文档

db> db.blog.update
function (query, obj, upsert, multi)
query:条件
obj:对象,更新的类容
upsert:判断更新的条件是否存在
multi:默认情况下更新只对符合匹配条件的第一个文档执行操作,要是这个为true,就是配置内容所以都更新

文档替换

当前的数据类型是

wangaimin> db.test.findOne({"name":"bob"})
{
        "_id" : ObjectId("58e4b6410b8bd344936c8553"),
        "name" : "bob",
        "email" : "bob@email.com.cn",
        "content" : "nice post"
}

我需要变成这个样子:

wangaimin> db.test.find({"name" : "bob"})
{ "_id" : ObjectId("58e4b6410b8bd344936c8553"), 
"name" : "bob", 
"comments" : { "email" : "bob@email.com.cn", "content" : "nice post" } 
}

操作步骤是:

wangaimin> var Test=db.test.findOne({"name":"bob"})
Test.comments={"email":Test.email,"content":Test.content}
delete Test.content
delete Test.email
db.test.update({"name" : "bob"},Test)
其实这个地方有一个坑,就是_id,如果你匹配中有多个name="bob",你就会报错,_id必须是唯一的,所以可以也可以执行delete Test._id,这里没有写的很详细,大家可以仔细想一下,如果不想是没有记忆点

使用修改器:

1,$set修改器

修改之前:
wangaimin> db.test.find({"name" : "bob"})
{ "_id" : ObjectId("58e4b6410b8bd344936c8553"), "name" : "bob", "comments" : { "email" : "bob@email.com.cn", "content" : "nice post" } }

命令:db.test.update({"name" : "bob"},{$set:{"name":"BOB"}})
修改之后:
wangaimin> db.test.find({"name" : "BOB"})
{ "_id" : ObjectId("58e4b6410b8bd344936c8553"), "name" : "BOB", "comments" : { "email" : "bob@email.com.cn", "content" : "nice post" } }

修改内嵌文档:
命令:wangaimin> db.test.update({"name" : "BOB"},{$set:{"comments.content":"change le"}})
修改之后:
wangaimin> db.test.find({"name" : "BOB"})
{ "_id" : ObjectId("58e4b6410b8bd344936c8553"), "name" : "BOB", "comments" : { "email" : "bob@email.com.cn", "content" : "change le" } }
2,$inc 增加和减少
注意:$inc 键的值必须是数字,不能为字符串数组或其他非数字的值
db.test.find()
{ "_id" : ObjectId("58e4bb4b0b8bd344936c8554"), "number" : 10 }
wangaimin> db.test.update({"number":10},{$inc:{"number":3}})
wangaimin> db.test.find()
{ "_id" : ObjectId("58e4bb4b0b8bd344936c8554"), "number" : 13 }

3,$push添加数组

如果数组已经存在,$push会向已有的数组末尾加入一个元素,要是没有就创建一个新的数组

 db.test.find()
{ "_id" : ObjectId("58e4bd5f0b8bd344936c8555"), "school" : "bd" }
db.test.update({"school":"bd"},{$push,{"list":{"name":"zhangsan","age":20}}})

db.test.find()
{ "_id" : ObjectId("58e4bd5f0b8bd344936c8555"), "school" : "bd", "list" : [ { "name" : "zhangsan", "age" : 20 } ] }

4,使用$each添加多个值

db.test.update({"school":"bd"},{$push:{"list":{$each:[{"name":"zhangsan","age":21},{"name":"zhangsan","age":22},{"name":"zhangsan","age":23},{"name":"zhangsan","age":24}]}}})

{ "_id" : ObjectId("58e4bd5f0b8bd344936c8555"), "school" : "bd", "list" : [ { "name" : "zhangsan", "age" : 20 }, { "name" : "zhangsan", "age" : 21 }, { "name" : "zhangsan", "age" : 22 }, { "name" : "zhangsan", "age" : 23 }, { "name" : "zhangsan", "age" : 24 } ] }

5,使用$slice限制个数,必须使用$each

使用$slice限制数组长度,如果$slice:-10,如果数组的长度小于10($push之后),那么所以的元素都会保留,如果数组的元素大于10,只有最后10个元素会报错,重点$slice的值必须是负数

wangaimin> db.test.find({"name":"test"})
{ "_id" : ObjectId("58e4c1d30b8bd344936c8556"), "name" : "test", "id" : [ 1, 2, 3, 4, 5, 7, 7, 1, 2, 3, 4, 5, 5 ] }
wangaimin> db.test.update({"name":"test"},{$push:{"id":{$each:[1,2,3],$slice:-5}}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
wangaimin> db.test.find({"name":"test"})
{ "_id" : ObjectId("58e4c1d30b8bd344936c8556"), "name" : "test", "id" : [ 5, 5, 1, 2, 3 ] }

6,将数组作为数据集使用($ne,$addToSet)

因为数组的元素是可以重复的,设置这个就是让数组的元素不可以重复



您可能感兴趣的文档:

--结束END--

本文标题: monggodb学习过程--update

本文链接: https://www.lsjlt.com/news/39213.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • FluentMybatis学习之Update语法实践
    目录前言数据准备Update语法简单的写法UpdateByEntity根据表实体更新数据UpdateByExclude根据表实体排除更新数据applyFunc总结前言 本篇文章主要针...
    99+
    2024-04-02
  • solaris学习3:启动过程
       #---------- ADDED BY BOOTADM - DO NOT EDIT ---------- title Oracle Solaris 10 8/11 s10x_u10wos_17b X86 find...
    99+
    2023-01-31
    过程 solaris
  • JAVA MyBatis入门学习过程记录
    目录一、Mybatis1、mybatis-config.xml2、Mapper.xml3、db.properties4、MybatisUtils工具类5、多对一AND多对一:6、使用...
    99+
    2024-04-02
  • 总结H3CNE学习过程和其他
    虽然一个H3CNE算不上什么,但是对我这个外行来说,通过对H3CNE的学习,使我能够在网工这个方向上入门了,我也是比较欣慰的,我今年26岁,已经在干电工有5年时间了,现在在莱钢干钢铁生产线的热线抢修电工,抢修天车的。发个图给大家看吧, 这...
    99+
    2023-01-31
    过程 H3CNE
  • 通过 ChatGPT 学习 Python
    先决条件 您需要一个 OpenAI 帐户才能开始与 ChatGPT 交互。如果您还没有这样做,请在 OpenAI 网站上注册一个帐户。  什么是 ChatGPT? GPT(Generative Pre-training Transfor...
    99+
    2023-09-01
    chatgpt 学习 python
  • Java学习过程的重点有哪些
    本篇文章给大家分享的是有关Java学习过程的重点有哪些,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Java学习过程的重点主要说说Java的几大块吧,无法说得很细,因为其实每一...
    99+
    2023-06-03
  • Java、Laravel和Spring学习笔记:如何避免学习过程中的挫折?
    学习编程语言是一个充满挑战的过程,特别是对于初学者来说。在学习过程中,可能会遇到各种问题,例如理解概念、调试代码和解决错误等。这些挫折可能会让初学者感到沮丧和失望。但是,不要失去信心,以下是一些建议,可以帮助你在学习Java、Larave...
    99+
    2023-11-10
    laravel spring 学习笔记
  • 想学习编程?这三个教程不容错过!
    编程已经成为当今世界的一项重要技能,无论你是学生、职场人士还是创业者,都可以从中受益。然而,对于初学者来说,学习编程可能会感到有些困难。不过,不用担心,今天我们将介绍三个非常优秀的编程教程,它们都是针对初学者设计的,帮助你快速掌握编程基础...
    99+
    2023-10-02
    javascript spring 教程
  • Python入门学习之Python流处理过程
    目录Faust简介高可用性分布式的快速灵活性安装绑定下载并从源文件中安装使用开发版本常见问题 Faust是一个流处理库,将kafka流中的思想移植到Python中 它被用于Robin...
    99+
    2024-04-02
  • 怎么对Python程序学习过程进行总结
    今天就跟大家聊聊有关怎么对Python程序学习过程进行总结,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。你需要注意一些问题,比如代码编程和调试过程中的问题,这些一定要仔细和认真,Py...
    99+
    2023-06-17
  • 如何通过实例学习Java对象的构造过程
    这篇文章给大家介绍如何通过实例学习Java对象的构造过程,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。下面提供一个项目中的错误实例,提供对其观察和分析,揭示出Java语言实例化一个对象具体过程,最后总结出设计Java类...
    99+
    2023-06-03
  • Python学习教程(Python学习路线):那些年我们踩过的那些坑。。。
    Python学习教程(Python学习路线):那些年我们踩过的那些坑。。。坑01 - 整数比较的坑在 Python 中一切都是对象,整数也是对象,在比较两个整数时有两个运算符 == 和 is ,它们的区别是:is 比较的是两个整数对象的id...
    99+
    2023-06-02
  • 通过demo学习OpenStack开发
    OpenStack是目前我所知的最大最复杂的基于Python项目。整个OpenStack项目包含了数十个主要的子项目,每个子项目所用到的库也不尽相同。因此,对于Python初学者和未接触过OpenStack项目的人来说,入门的难度相当大...
    99+
    2023-01-31
    demo OpenStack
  • 通过慕课网学习Python
    通过慕课网学习Python。慕课网-Python入门 老师是:廖雪峰大神。我觉得他讲的非常好。另外,慕课网的练习形式我很喜欢,所以给大家推荐一下。 我买了两本书:《Python编程从入门到实践》-人民邮电出版社 《Python机...
    99+
    2023-01-31
    慕课网 Python
  • 学习嵌入式Linux过程是怎么样的
    这篇文章给大家介绍学习嵌入式Linux过程是怎么样的,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。我专业是电子信息工程,在初入大学的时候,我们的班主任便要我们多多去了解一些关于电子方面的知识。后来我了解到了嵌入式,继而...
    99+
    2023-06-05
  • 学习Python过程中该注重哪些细节
    这篇文章主要介绍“学习Python过程中该注重哪些细节”,在日常操作中,相信很多人在学习Python过程中该注重哪些细节问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”学习Python过程中该注重哪些细节”的疑...
    99+
    2023-06-17
  • 想学习ASP和Spring?这些学习笔记不可错过!
    如果你正在学习ASP和Spring框架,那么你一定需要一些好的学习笔记来帮助你更好地理解这些框架的工作原理和使用方法。在这篇文章中,我们将为你介绍一些非常有用的学习笔记,这些笔记不仅可以帮助你学习ASP和Spring,还可以帮助你更好地理...
    99+
    2023-11-14
    spring 学习笔记 http
  • GO语言学习笔记:如何通过学习Laravel来提升您的编程技能?
    随着互联网的发展,编程已经成为了一个非常热门的职业。而在众多的编程语言中,GO语言因其高效、安全、简单易学等特点而备受青睐。如果你是一名初学者,那么学习Laravel可能是一个不错的选择,因为它可以帮助你更好地理解GO语言的编程思想。 L...
    99+
    2023-10-23
    学习笔记 面试 laravel
  • JavaScript编程通过Matlab质心算法定位学习
    目录Matlab质心算法Matlab作为封闭的商业软件,受美国政府左右,无视商业道德,故不建议使用。如果喜欢Matlab语法,可移步开源的octave,其语法与matlab完全相同。...
    99+
    2024-04-02
  • Python进程学习
    线程及进程概念可自行学习 Unix/Linux操作系统提供了一个fork()系统调用,它非常特殊。普通的函数调用,调用一次,返回一次,但是fork()调用一次,返回两次,因为操作系统自动把当前进程(称为父进程)复制了一份(称为子进程),然后...
    99+
    2023-01-31
    进程 Python
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作