mongo: 改
语法:db.CollectionName.upadte(查询表达式,新值,选项);
查询表达式:定位哪些列是要被修改的列(即使查询表达式能命中多行,默认也只改一行,如果想改多行,可以用multi选项,在可选项中将会讲到)
新值:要被修改的列,要被修改成的样子
选项:可选项
例:db.stu.update({name:’poxi’},{name:’yanpoxi’})
注意:上面的操作是指选中stu表中name属性值为’poxi’的文档,并把其文档值改为{name:’yanpoxi’}
结果:文档中的其他列都不见了,改后只有_id和name这两列,即新文档直接替换了旧文档,而不是修改
如果是想修改文档的某列,可以使用$Set关键字
db.CollectionName.update(查询表达式,{$Set:新值});
db.CollectionName.update({name:’poxi},{$Set:{name:’yanpoxi’}});
关键字还有很多,下面我们插入一条新的文档:
sb.stu.insert({name:’kukong’,age:’500’,sex:’m’,jingu:’true’});

$set:修改某一列的值:我们把kukong改为dzsf(斗战胜佛)
$inc:某一列的值自增:取经花费16年,年龄变为516
$rename:修改某一列的名称:我们把性别这一列(sex),改为gender
$unset:删掉某一列:取经成功后,取掉了紧箍,所以删掉jingu这一列。
db.stu.update({name:’kukong’},{$set:{name:’dzsf’},$inc:{age:’16’},$rename:{sex:gender},$unset{‘jingu’:1}})
解释:
红色部分是查询表达式(用于匹配哪些记录需要修改)
蓝色部分是新值(设置新值使用了很多关键字)
这里面没有Option

$setOnInsert:当upsert为true时,并且发生了insert,可以补充字段(upsert是可选项,意思是如果没有匹配的行,则直接插入该行)

Option的作用:
{upsert:true/false,multi:true/false}
Upsert---是指没有匹配的行,则直接插入该行(和mysql中的replace一样)
例:本来是没有name的属性值为无用的文档,所以直接插入了。 db.stu.update({name:’wuyong’},{$set:{name:’junshiwuyong’}},{upsert:true});

multi:是指修改多上,前面我们提到过,即使查询表达式能匹配多行,默认也只修改一行,如果想修改多行,需要设置multi:true
db.stu.update({gender:’m’},{$set:{gender:’male}});只修改一行

db.stu.update({gender:’m’},{$set:{gender:’male’}},{multi:true});所有gender属性值为’m’的文档,都修改为gender:’male’
解释:红色的是查询表达式,蓝色的是设置新值,绿色的是Option

mongo: 改的更多相关文章
- mongo 改数据库名称
用命令 db.copyDatabase('old_name', 'new_name') 可以备份出一个新的数据库. 然后 use old_name 并db.dropDatabase() 即可删除旧的 ...
- 谈一谈NOSQL的应用,Redis/Mongo
1.心路历程 上年11月份来公司了,和另外一个同事一起,做了公司一个移动项目的微信公众号,然后为了推广微信公众号,策划那边需要我们做一些活动,包括抽奖,投票.最开始是没有用过redis的,公司因为考虑 ...
- segmentfault.com mongo出识以及对数组的操作
https://segmentfault.com/a/1190000003951602 首先推荐个工具,no-sql-manager-for-mongodb-professional,虽然收费,但是每 ...
- mongo的安装
windows: 1 安装scons (1): 下载python2.7, 使用x86_32位,因为scons只有32位安装包可用, http://www.python.org/download/rel ...
- c#开发Mongo笔记第八篇
到今天为止,Mongo开发的权限管理系统功能就做完了,剩下的就是完善构架,优化结构,只是现在c#操作Mongo的各种操作基本都掌握了 说到权限管理系统,其实再简单不过了,在关系型数据的是时代,我们通常 ...
- c#开发Mongo笔记第四篇
今天是个伟大的日子,不得不说小苹果的歌词真是深入人心啊. 不过今天伟大并不是因为我种下一颗种子,而是我从今天不再写demo,而是进入项目的正式开发当中,毕竟项目时间有限(想必各位码农也都深有体会吧), ...
- Mongo命令行中执行CRUD
在命令行中使用mongo自带的shell命令来执行CRUD操作 首先链接到数据库 增 db.qiao.insert({"qq":1}) db.qiao.save({"qq ...
- mongo安装、备份与常见命令整理
http://zlboy888.blog.163.com/blog/static/315357072012919241104/ 1 下载安装包 官方下载地址:http://www.mongodb.o ...
- mongo 学习教程(全)
看的是爱酷学习网的视频:http://www.icoolxue.com/album/show/98 01 安装 1.先建mongoDB-data文件夹存数据 2.安装DB 3.设置环境变量:把bin目 ...
随机推荐
- [Oracle] Setup DataGuard
Oracle一步步搭建DataGuard DataGuard环境: OS: SuSe 10 Primary DB: IP address:1.1.1.1 user:root passwd:****** ...
- flume 使用
基本操作: 编写配置文件: # 指定Agent的组件名称 a1.sources = r1 a1.sinks = k1 a1.channels = c1 # 指定Flume source(要监听的路径) ...
- 二十六个月Android学习工作总结【转】
原文:二十六个月Android学习工作总结 1.客户端的功能逻辑不难,UI界面也不难,但写UI花的时间是写功能逻辑的两倍. 2.写代码前的思考过程非常重要,即使在简单的功能,也需要在本子上把该 ...
- iOS手势UIGestureRecognizer的使用失效问题
问题:视图正常展示在界面中,父层是放在window上的,底部的一个控件的点击事件失效(所有设置都正常) 解决思路:虽然视图能够正常展示,但是发现父类视图的底部尺寸比子类的视图的尺寸小,也就是说上层视图 ...
- 写给小白看的 JavaScript 异步
某天突然写了个方法要从后台调用数据,显示在前台页面,但是输出结果总是空 undefined,得不到数据.多方找资料才发现,原来是入了 JS 异步的 “坑”. 我们常常听到单线程.多线程.同步.异步这些 ...
- Struts2 学习笔记——struts.xml文件之Bean的配置
Struts2的大部分核心组件不是以硬编码的形式写在代码中,而是通过自身的IoC容器来管理的. Struts2以可配置的形式来管理核心组件,所以开发者可以很容易的扩展框架的核心组件.当开发者需要扩展或 ...
- Maven笔记:
启动tomcat的时候报这样的错误:java.lang.ClassNotFoundException: org.springframework.web.filter.CharacterEncoding ...
- Tarjan缩点+Spfa最长路【p3627】[APIO2009] 抢掠计划
Description Siruseri 城中的道路都是单向的.不同的道路由路口连接.按照法律的规定, 在每个路口都设立了一个 Siruseri 银行的 ATM 取款机.令人奇怪的是,Siruseri ...
- POJ 2886 Who Gets the Most Candies? (线段树)
[题目链接] http://poj.org/problem?id=2886 [题目大意] 一些人站成一个圈,每个人手上都有一个数字, 指定从一个人开始淘汰,每次一个人淘汰时,将手心里写着的数字x展示 ...
- [置顶]
kubernetes创建资源yaml文件例子--pod
kubernetes创建pod的yaml文件,参数说明 apiVersion: v1 #指定api版本,此值必须在kubectl apiversion中 kind: Pod #指定创建资源的角色/类型 ...