语法: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: 改的更多相关文章

  1. mongo 改数据库名称

    用命令 db.copyDatabase('old_name', 'new_name') 可以备份出一个新的数据库. 然后  use old_name 并db.dropDatabase() 即可删除旧的 ...

  2. 谈一谈NOSQL的应用,Redis/Mongo

    1.心路历程 上年11月份来公司了,和另外一个同事一起,做了公司一个移动项目的微信公众号,然后为了推广微信公众号,策划那边需要我们做一些活动,包括抽奖,投票.最开始是没有用过redis的,公司因为考虑 ...

  3. segmentfault.com mongo出识以及对数组的操作

    https://segmentfault.com/a/1190000003951602 首先推荐个工具,no-sql-manager-for-mongodb-professional,虽然收费,但是每 ...

  4. mongo的安装

    windows: 1 安装scons (1): 下载python2.7, 使用x86_32位,因为scons只有32位安装包可用, http://www.python.org/download/rel ...

  5. c#开发Mongo笔记第八篇

    到今天为止,Mongo开发的权限管理系统功能就做完了,剩下的就是完善构架,优化结构,只是现在c#操作Mongo的各种操作基本都掌握了 说到权限管理系统,其实再简单不过了,在关系型数据的是时代,我们通常 ...

  6. c#开发Mongo笔记第四篇

    今天是个伟大的日子,不得不说小苹果的歌词真是深入人心啊. 不过今天伟大并不是因为我种下一颗种子,而是我从今天不再写demo,而是进入项目的正式开发当中,毕竟项目时间有限(想必各位码农也都深有体会吧), ...

  7. Mongo命令行中执行CRUD

    在命令行中使用mongo自带的shell命令来执行CRUD操作 首先链接到数据库 增 db.qiao.insert({"qq":1}) db.qiao.save({"qq ...

  8. mongo安装、备份与常见命令整理

    http://zlboy888.blog.163.com/blog/static/315357072012919241104/ 1 下载安装包  官方下载地址:http://www.mongodb.o ...

  9. mongo 学习教程(全)

    看的是爱酷学习网的视频:http://www.icoolxue.com/album/show/98 01 安装 1.先建mongoDB-data文件夹存数据 2.安装DB 3.设置环境变量:把bin目 ...

随机推荐

  1. fmap为什么可以用function作为第二个参数

    看看fmap的类型 fmap :: Functor f => (a -> b) -> f a -> f b 很明显的,第一个参数是function,第二个参数是functor的 ...

  2. (一)使用sklearn做各种回归

    #申明,本文章参考于 https://blog.csdn.net/yeoman92/article/details/75051848 import numpy as np import matplot ...

  3. 在16aspx.com上下了一个.net程序,怎么修改它的默认登录名和密码?

    正常应该有个login.aspx文件,找到登入按钮事件,查看验证用户名密码事件,这个验证就有去搜索用户表,然后在这个用户表修改用户名密码就行了.不排除其他表有用用户名关联

  4. J.U.C并发框架源码阅读(十六)FutureTask

    基于版本jdk1.7.0_80 java.util.concurrent.FutureTask 代码如下 /* * ORACLE PROPRIETARY/CONFIDENTIAL. Use is su ...

  5. 51nod 1001 数组中和等于K的数对【二分查找/排序】

    1001 数组中和等于K的数对 基准时间限制:1 秒 空间限制:131072 KB 分值: 5 难度:1级算法题  收藏  关注 给出一个整数K和一个无序数组A,A的元素为N个互不相同的整数,找出数组 ...

  6. 51nod 1182 完美字符串【字符串排序+哈希】

    1182 完美字符串 题目来源: Facebook Hacker Cup选拔 基准时间限制:1 秒 空间限制:131072 KB 分值: 5 难度:1级算法题  收藏  关注 约翰认为字符串的完美度等 ...

  7. HDU 5900 QSC and Master (区间DP)

    题目链接   http://acm.hdu.edu.cn/showproblem.php?pid=5900 题意:给出序列$A_{i}.key$和$A_{i}.value$,若当前相邻的两个数$A_{ ...

  8. js加强

    js加强 js深度解析 闭包讲解 1.闭包是和gc(垃圾回收机制)相关的 2.闭包实际上是涉及一个对象属性  何时被gc回收的问题 3怎样产生闭包? <script type="tex ...

  9. Python的并发并行[1] -> 线程[3] -> 多线程的同步控制

    多线程的控制方式 目录 唤醒单个线程等待 唤醒多个线程等待 条件函数等待 事件触发标志 函数延迟启动 设置线程障碍 1 唤醒单个线程等待 Condition类相当于一把高级的锁,可以进行一些复杂的线程 ...

  10. [洛谷3808]【模板】AC自动机(简单版)

    题目大意: 给定$n$个模式串$p(\sum|p_i|\le10^6)$和一个$t(|t|\le10^6)$,求在$t$中被匹配的$p$的个数. 思路: AC自动机模板题,注意$t$中一个字符可能对应 ...