mongoDB 更改操作

格式对比 MySQL

update table set .... where ....
db.collection.updateOne(query,update,upsert)

修改函数

updateOne  修改首个

db.collection.updateOne(query,update,upsert)

功能  修改第一个复合条件的文档

参数

            query   筛选条件,用法同 find
update 要修改的数据项, 配合修改操作符
upsert bool类型
设置为 true 未查到则插入新文档
设置为 false 默认是 false, 未查到则不修改

实例

将 aa 的年龄修改为 19 岁
> db.class.updateOne({name:"aa"},{$set:{age:19}})
{ "acknowledged" : true, "matchedCount" : 1, "modifiedCount" : 1 }
未添加 upsert 为 true 时, 无匹配, 因此没变化
> db.class.updateOne({name:"ww"},{$set:{age:19}})
{ "acknowledged" : true, "matchedCount" : 0, "modifiedCount" : 0 }
设置 upsert 为 true 时, 无匹配则会插入新文档
> db.class.updateOne({name:"ww"},{$set:{age:19}},{upsert:true})
{
"acknowledged" : true,
"matchedCount" : 0,
"modifiedCount" : 0,
"upsertedId" : ObjectId("5c779dbbe0253ec903878cd0")

updateMany  修改所有

db.collection.updateMany(query,update,upsert)

功能  修改所有符合条件的文档

参数  同 updateOne

实例

将所有年龄 小于18 的修改为 21
> db.class.updateMany({age:{$lt:18}},{$set:{age:21}})
{ "acknowledged" : true, "matchedCount" : 6, "modifiedCount" : 6 }
>

update  修改所有

db.collection.update(query,update,upsert,multi)

功能  修改文档

参数

query   用法同 updateOne/updateMany
update   用法同 updateOne/updateMany
upsert 功能同 updateOne/updateMany
写法上不在写在 {} 中, 直接 upsert=true/false 即可 multi   bool 值
multi=false 同 updateOne 只修改首条 默认为 false
multi=true 同 updateMany 修改全部

ps:

  mongoDB 全部的参数都位置传参,如果想传第四个,就必须传入第三个参数

实例

> db.class.update({age:21},{$set:{age:88}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 }) upsert 使用的时候,直接写 bool 即可
> db.class.update({name:"yy"},{$set:{age:88}},true)
WriteResult({
"nMatched" : 0,
"nUpserted" : 1,
"nModified" : 0,
"_id" : ObjectId("5c77a57ee0253ec903878d10")
}) multi 使用同 upsert, 直接写 bool 即可
> db.class.update({age:21},{$set:{age:88}},true,true)
WriteResult({ "nMatched" : 5, "nUpserted" : 0, "nModified" : 5 })
>

findOneAndUpdate  查找首个并修改

db.collection.findOneAndUpdate(query,update)

功能  查找第一个复合条件文档, 然后修改

参数  query update 用法同 updateOne/updateMany

返回值 修改前的文档

实例

查找名字 叫 cc 文档, 修改年龄为 26 
> db.class.findOneAndUpdate({name:"cc"},{$set:{age:26}})
{
"_id" : ObjectId("5c77910c4b2b9d43636830ca"),
"name" : "cc",
"age" : 88,
"sex" : "b",
"hobby" : [
"python",
"football",
"computer"
]
}

findOneAndReplace  查找首个并替换

db.collection.findOneAndReplace(query,doc)

功能  查找第一个复合条件文档, 然后替换

参数

  query   用法同 updateOne/updateMany

  doc     要替换的文档

返回值 修改前的文档

查找 名字 叫 cc 的文档, 将内容替换成 名字叫 zz 年龄 16 岁
> db.class.findOneAndReplace({name:"cc"},{name:"zz",age:16})
{
"_id" : ObjectId("5c77910c4b2b9d43636830ca"),
"name" : "cc",
"age" : 26,
"sex" : "b",
"hobby" : [
"python",
"football",
"computer"
]
}
如果 query 设置为空,则可以对第一条内容进行替换
> db.class.findOneAndReplace({},{name:"kk",age:16})
{
"_id" : ObjectId("5c7790c94b2b9d43636830c8"),
"name" : "aa",
"age" : 19,
"sex" : "b",
"hobby" : [
"draw",
"dance",
"running"
]
}

mongoDB 修改操作符(修改器)

修改的时候必须要使用修改器

如果用较老的 update 方法 确实可以不使用修改器, 但是实现效果是替换很不理想

本意想 查找 名字 yy 的文档,将 age 改为 99 
> db.class.update({name:"yy"},{age:99})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
修改前: { "name" : "yy", "age" : 88 }
修改后: { "age" : 99 }

$set

修改一个域, 或者增加一个域

查找 age 为 99 的文档, 将名字 改为 yy
> db.class.update({age:99},{$set:{name:"yy"}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
修改前:{ "age" : 99}
修改后:{ "age" : 99, "name" : "yy" }

$unset

删除一个域

ps:

官方推荐 选定被删除域的时候值用 "" 空即可,当前其实随便字符都行,重点是匹配域, 而不是值

去除掉 年龄 99 的文档中的 age 域
> db.class.update({age:99},{$unset:{age:""}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
修改前: { "age" : 99, "name" : "yy" }
修改后: { "age" : 99}

$rename

重命名一个域

将所有的含有 sex 域的文档的 sex 域 改名为 gender 
> db.class.updateMany({sex:{$exists:true}},{$rename:{sex:"gender"}})
{ "acknowledged" : true, "matchedCount" : 6, "modifiedCount" : 6 }

其实也不用刻意的去筛选, 系统会自动对存在该域的文档进行处理, 所以直接  {}  即可

> db.class.updateMany({},{$rename:{gender:"sex"}})
{ "acknowledged" : true, "matchedCount" : 10, "modifiedCount" : 6 }

$inc

加法修改器

让所有文档的 年龄 +1 
> db.class.updateMany({},{$inc:{age:1}})
{ "acknowledged" : true, "matchedCount" : 10, "modifiedCount" : 10 }
修改前:  { "name" : "yy" }
修改后: { "name" : "yy", "age" : 1 }

ps:

  值可以是正数,负数或者小数

  么有年龄字段的会产生 age:1 字段

$mul

乘法修改器

用法,参数同加法,只是运算由加法换成乘法

ps:

  怎么除法? *0.5 = /2

$setOnInsert

当使用 update*  插入文档时 ,作为 补充 内容

update* 在筛选无法命中存在文档时可以添加新内容,但是插入内容是全面 query update 部分

当需要加入 额外字段 的时候, 使用此修改器

查找 name 为 77 age 为 15 的文档(查不到), 设置内容为 eat 域 的值为 many ,并且 额外加入 run 域 值为 fast 
> db.class.updateOne({name:"77",age:15},{$set:{eat:"many"},$setOnInsert:{run:"fast"}},{upsert:true})
{
"acknowledged" : true,
"matchedCount" : 0,
"modifiedCount" : 0,
"upsertedId" : ObjectId("5c788dbce0253ec903878dba")
}
>

ps:

  由此可见其实 update 的第二个参数 update 是可以多个修改器同时使用的

查找 名字 为 77 的文档, 将将 名字 改为 22 , 并且 去除 eat 域
> db.class.update({name:"77"},{$set:{age:22},$unset:{eat:""}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
修改前: { "age" : 15, "name" : "77", "eat" : "many", "run" : "fast" }
修改后: { "age" : 22, "name" : "77", "run" : "fast" }

$max

指定值不低于下限

指定某个域的值如果小于该值则修改为该值, 大于则不变

指定 name 为 77 的文档的 age 域 的值 不能小于 20 
> db.class.update({name:"77"},{$max:{age:20}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 0 })
修改前: { "age" : 22, "name" : "77", "run" : "fast" }
修改后: { "age" : 22, "name" : "77", "run" : "fast" }
指定 name 为 77 的文档 的 age 域 的值 不能小于 30
> db.class.update({name:"77"},{$max:{age:30}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
修改前: { "age" : 22, "name" : "77", "run" : "fast" }
修改后: { "age" : 30, "name" : "77", "run" : "fast" }

$min

指定值不低于上限

用法同 $max 控制最大值不超过设定值,大于了就改成设定值

mongoDB 数组修改器

$push

向数组中添加一项

查找 name 为 dd 的文档, 将 hobby 域内的数组 增加一项 sing
> db.class.update({name:"dd"},{$push:{hobby:"sing"}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
修改前: { "name" : "dd", "age" : 88, "hobby" : [ "football", "computer" ], "sex" : "b" }
修改后: { "name" : "dd", "age" : 88, "hobby" : [ "football", "computer", "sing" ], "sex" : "b" }

$pushAll

向数组中添加多项

查找 name 为 dd 的文档, 将 hobby 域内的数组 增加多项 eat、run、cry
> db.class.update({name:"dd"},{$pushAll:{hobby:["eat","run","cry"]}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
修改前:  { "name" : "dd", "age" : 88, "hobby" : [ "football" ], "sex" : "b" }
修改后: { "name" : "dd", "age" : 88, "hobby" : [ "football", "eat", "run", "cry" ], "sex" : "b" }

$pull

从数组中删除一个值,如果有重复的值, 会全部删除

查找 名字 为 dd 删除 hobby 域内数组 的 eat
> db.class.update({name:"dd"},{$pull:{hobby:"eat"}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
修改前: { "name" : "dd", "age" : 88, "hobby" : [ "football", "eat", "run", "cry" ], "sex" : "b" }
修改后: { "name" : "dd", "age" : 88, "hobby" : [ "football", "run", "cry" ], "sex" : "b" }

$pullAll

从数组中删除多个值、如果有重复的值, 会全部删除

删除的时候也可以按照条件删除

查找 名字 为 dd 的文档,删除 hobby 域内数组的 eat、run
> db.class.update({name:"dd"},{$pullAll:{hobby:["eat","run"]}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
修改前: { "name" : "dd", "age" : 88, "hobby" : [ "football", "eat", "run", "cry" ], "sex" : "b" }
修改后: { "name" : "dd", "age" : 88, "hobby" : [ "football", "cry" ], "sex" : "b" }

$pop

弹出数组中一项

只能弹出两头的第一个内容

  取值 为 1 弹出最后一项

  取值 为 -1 弹出第一项

删除 名字 为 dd 的 hobby 域内数组的 第一项
> db.class.update({name:"dd"},{$pop:{hobby:1}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
修改前: { "name" : "dd", "hobby" : [ "football", "eat", "run", "cry" ] }
修改后: { "name" : "dd", "hobby" : [ "football", "eat", "run" ] } 删除 名字 为 dd 的 hobby 域内数组的 最后一项
> db.class.update({name:"dd"},{$pop:{hobby:-1}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
修改前: { "name" : "dd", "hobby" : [ "football", "eat", "run", "cry" ] }
修改后: { "name" : "dd", "hobby" : [ "eat", "run", "cry" ] }

$addToSet

向数组中添加一项

不能和已有值重复

如果是重复值则不做任何操作

查找 name 为 mm 的文档, 将 score 域内数组 添加 18 ,若存在则不作修改
> db.class.updateOne({name:"mm"},{$addToSet:{score:18}})
{ "acknowledged" : true, "matchedCount" : 1, "modifiedCount" : 1 }
修改前: { "name" : "mm", "age" : 12, "score" : [ 12, 16, 17 ] }
修改后: { "name" : "mm", "age" : 12, "score" : [ 12, 16, 17, 18 ] }
查找 name 为 mm 的文档, 将 score 域内数组 添加 18 ,若存在则不作修改
> db.class.updateOne({name:"mm"},{$addToSet:{score:18}}) 
{ "acknowledged" : true, "matchedCount" : 1, "modifiedCount" : 1 }
修改前: { "name" : "mm", "age" : 12, "score" : [ 12, 16, 17, 18 ] }
修改后: { "name" : "mm", "age" : 12, "score" : [ 12, 16, 17, 18 ] }

$each

对多个值逐一操作

查找 name 为 mm 的文档, 将 score 域内数组 逐一添加 89,26
> db.class.updateOne({name:"mm"},{$push:{score:{$each:[89,26]}}})
{ "acknowledged" : true, "matchedCount" : 1, "modifiedCount" : 1 }
修改前: { "name" : "mm", "age" : 12, "score" : [ 12, 16, 17, 18 ] }
修改后: { "name" : "mm", "age" : 12, "score" : [ 12, 16, 17, 18, 89, 26 ] }

$position

指定位置插入

需要配合 $each 使用, $each 提供值

$position 指定索引位置

 查找 name 为 mm 的文档,在 score 域内数组 将 90 添加在 索引 0 的位置
> db.class.updateOne({name:"mm"},{$push:{score:{$each:[],$position:0}}})
{ "acknowledged" : true, "matchedCount" : 1, "modifiedCount" : 1 }
修改前: { "name" : "mm", "age" : 12, "score" : [ 12, 16, 17, 18 ] }
修改后: { "name" : "mm", "age" : 12, "score" : [ 90, 12, 16, 17, 18 ] }

$sort

对数组排序

搭配 $each 使用

  1 为升序,

  -1 为降序

查找 name 为 mm 的文档 ,将 score 域内数组 升序排列
> db.class.updateOne({name:"mm"},{$push:{score:{$each:[],$sort:1}}})
{ "acknowledged" : true, "matchedCount" : 1, "modifiedCount" : 1 }
修改前: { "name" : "mm", "age" : 12, "score" : [ 90, 12, 19, 17, 18 ] }
修改后: { "name" : "mm", "age" : 12, "score" : [ 12, 17, 18, 19, 90] }

mongoDB 文档操作_改的更多相关文章

  1. mongoDB 文档操作_删

    mongoDB 文档删除 MySQL对比 mysql delete from table where ... mongo db.collection.deleteOne(query) 删除函数 del ...

  2. mongoDB 文档操作_查

    基本查询命令 find 查找复合条件的所有文档 命令 db.collection.find(query,field) 参数 query 查找条件 格式: {ssss:"xxx"}是 ...

  3. mongoDB 文档操作_增

    增加 / 插入 /保存 单文档插入 命令 db.collection.insertOne(doc) 功能 向被 use 的数据库中插入数据 实例 db.class.insertOne({"n ...

  4. mongoDB文档操作

    数据库操作无非就是增.删.改.查.这篇主要介绍增.删.改. 1.增 Mongodb插入操作很简单,使用关键字“insert”.实例: > db.test.blog.insert({"h ...

  5. MongoDB (八) MongoDB 文档操作

    一. MongoDB 插入文档 insert() 方法 要插入数据到 MongoDB 集合,需要使用 MongoDB 的  insert() 或 save() 方法. 语法 insert() 命令的基 ...

  6. mongoDB文档操作【增删改】

    MongoDB 插入文档 文档的数据结构和JSON基本一样. 所有存储在集合中的数据都是BSON格式. BSON是一种类json的一种二进制形式的存储格式,简称Binary JSON. 插入文档 Mo ...

  7. MongoDB自学------(3)MongoDB文档操作

    一.插入文档 二.查询文档 三.更新文档 可以看到标题(title)由原来的 "Mongodb" 更新为了 "MongoDBtest". 以上语句只会修改第一条 ...

  8. MongoDB入门---文档操作之增删改

    之前的两篇文章,已经分享过关于MongoDB的集合还有数据库的各种操作,接下来就涉及到最主要的喽,那就是数据方面的操作,在这里叫做文档操作.话不多说,大家来看正文.     首先来看一下它的数据结构: ...

  9. mongodb安装,库操作,集合操作(表),文档操作(记录)

    安装 1.下载地址 https://fastdl.mongodb.org/win32/mongodb-win32-x86_64-2008plus-ssl-4.0.8-signed.msi 2.如果报没 ...

随机推荐

  1. JS最简单的字符串转数字类型

    以前无休止的写parseInt,特别复杂,现在只需要一个加号,就可以完成对字符串的转换 1 === +"1" amazing!

  2. 【AO笔记】有关TIN数据集的常用介绍

    写论文查了很多TIN的接口和属性,特此来记录一下. 转载请注明出处:博客园@秋意正寒,B站同名. 未完待续 1. Tin数据集在ArcGIS中的描述 Tin数据集在磁盘中,被ArcGIS以文件夹形式管 ...

  3. 广州.NET微软技术俱乐部 - 新秀计划

    本文正在写草稿中, 发布时会在群里单独通知

  4. ArcGIS for JavaScript学习(一)

    一  API准备 从网上下载开发包:ArcGIS for JavaScript(百度网盘地址) sdk中含有API的帮助和例子 2.离线部署(以IIS为例) 配置IIS(详见网络):解压离线包,包中的 ...

  5. 浅谈Semaphore类

    Semaphore类有两个重要方法 1.semaphore.acquire(); 请求一个信号量,这时候信号量个数-1,当减少到0的时候,下一次acquire不会再执行,只有当执行一个release( ...

  6. 我的新书《Android App开发从入门到精通》终于出版啦

    前言 经过了两年多终于完成了这本书,2016年9月份开始写的,到今天为止2年零2个月,本书的内容大部分是去年完成的,看过我去年总结的读者可能知道,去年事情很多太忙了,导致本命年这本书没有上架(有点小小 ...

  7. GitHub和75亿美金

    如果你是看到了75亿进来的,还在纳闷前面那个github的是个什么,你可以走人了?如果你进来是想看到微软两个字的,请继续. 微软以75亿美金的股票收购Github这件事情,从周六一早我爬山到香山琉璃塔 ...

  8. UITableView编辑模式大全解

    1.UITableView 的编辑模式 进入编辑模式 代码体现 // 设置 editing 属性 tableView?.editing = true // 这个设置的时候是有动画效果的 tableVi ...

  9. 【模块04-大数据技术入门】02节-HDFS核心知识

    分布式存储 (1) 5PB甚至更大的数据集怎么存储 ? 所有数据分块,每个数据块冗余存储在多台机器上(冗余可提高数据块高可用性).另外一台机器上启动一个管理所有节点.以及存储在各节点上面数据块的服务. ...

  10. LInkedHashMap实现最近被使用(LRU)缓存

    在最近的面试中,我曾被多次问到,怎么实现一个最近最少使用(LRU)的缓存.缓存可以通过哈希表来实现,然而为这个缓存增加大小限制会变成另一个有意思的问题.现在我们看一下怎么实现. 最近最少使用缓存的回收 ...