MongoDB之修改器

$set  简单粗暴  {name: valuel}

  直接将key对应的值赋值给value、

db.xxoo.insert({}, {set: {key: value}})  // 添加字段

  相当于python中的dict['name'] = value

$unset  简单粗暴的删除字段

db.userinfo.updateOne({age: 18},{$unset: {age: 1}})  // 删除age字段

  相当于python中的del dict['name']。其中{age: 1}中的1也可以写其他值,总之布尔值为true即可。

$push  针对array的操作,添加

db.userinfo.updateOne({name: 'Ta'},{$push:{ghobby: 10}})  // 给ghobby字段添加10

  在array中追加一个新的元素,相当于python中的[].append('')。

$pull  针对array的操作,删除

db.userinfo.updateOne({name: 'Ta'},{$pull:{ghobby: 10}})  // 删除ghobby字段中的10

  删除array中的一个元素,相当于python中的[].remove(item)或者[].pop(-1)。

$pop  针对array的操作,删除

db.userinfo.updateOne({name: 'Ta'},{$pop:{ghobby: -1}})  // 删除ghobby字段中的第一个值

  当{ghobby: -1}中ghobby对应的值为-1时,则是正序删除第一个;ghobby对应的值为1时,则倒序删除第一个,即倒数第一个。 1与-1也可以写为其他值,正值从后往前删,负值从前往后删。

$inc  引用增加

db.userinfo.updateMany({},{$inc:{age: 1}})  // 给userinfo表中的age字段统一在原有的基础上增加1,当没有这个字段时,就创建一个,然后初始值为1.

$字符

  $  保存符合索引条件的下标

db.userinfo.updateOne({ghobby: 5},{$set:{'ghobby.2': '四'}})  // 将userinfo表中的ghobby字段中的索引为5的值修改为‘四’,{ghobby: 5}

  换另外一种方式

db.userinfo.updateOne({ghobby: 5},{$set:{'ghobby.$': '五'}})  // 将userinfo表中的ghobby字段中的值为5的元素替换为‘五’,{$set:{'ghobby.$': '五'}}中的$就是值为5的元素的索引,也就是,'ghobby.$'代指的就是值为5的这个元素。 

  当列表套列表的情况下只能使用一次$。

Object  字典操作

修改

db.userinfo.updateOne({name: 'Ta'},{$inc:{'Info.体重': -5}})  // 给userinfo表中的Info字段的体重元素减去5。

添加

db.userinfo.updateOne({name: 'Ta'},{$inc:{'Info.长度': 18}})  // 给userinfo表的Info字段添加一个值为18的长度元素

Array + Object

db.userinfo.updateOne({'ghobby.长度': 18}, {'$inc': {'ghobby.$.长度': 2}})  // 给userinfo表中的ghobby中的长度增加2

  使用$的好处是只是更改选中的这一条数据的具体的这个值,否则的话会修改这条记录中的所有的相关的值。

limit  限制显示

  从当前位置选择5个

db.userinfo.find({}).limit(5)  // 显示查到的前五条数据

skip  跳过

db.userinfo.find({}).skip(2)  // 从零开始跳过两条数据,显示剩下的所有的数据

sort  排序

db.userinfo.find({}).sort({ id:-1 })  // 根据id进行降序排序

limit + skip + sort

pymongo

0

MongoDB之修改器的更多相关文章

  1. MongoDB update修改器 目录

    MongoDB update修改器: 针对Fields的$修改器 $inc $set $unset MongoDB update修改器: 针对Arrays的$修改器 $push $pull $pop ...

  2. MongoDB update修改器: 针对Fields的$修改器 $inc $set $unset

    MongoDB update修改器: $inc $set $unset $push $pull $pop 针对Fields的$修改器 $set: { $set: { key: value } } $s ...

  3. MongoDB数组修改器更新数据(转)

    MongoDB数组修改器更新数据    这里,我们将了解一下数组修改器.数组,是我们经常看到和使用到的且非常有用的数据结构:它不仅可以通过索进行引用,还可以作为集合来使用.数组修改器,顾名思义,它是用 ...

  4. mongodb的修改器

    在mongodb中通常文档只会有一部分要更新,利用原子的更新修改器,可以做到只更新文档的一部分键值,而且更新极为高效,更新修改器是种特殊的键,用来指定复杂的更新操作,比如调整.增加.或者删除键,还可以 ...

  5. MongoDB update修改器: 针对Arrays的$修改器 $push $pull $pop

    针对Arrays的$修改器 $push : { $push: { key: value } } 它是用来对Array (list)数据类型进行 增加 新元素的,相当于我们Python中 list.ap ...

  6. 【MongoDB】4.MongoDB 原子修改器的 极速修改

    文档转自:http://blog.csdn.net/mcpang/article/details/7752736 对于文档的更新除替换外,针对某个或多个文档只需要部分更新可使用原子的更新修改器,能够高 ...

  7. mongodb修改器

    mongodb修改器 转载自:http://blog.csdn.net/mcpang/article/details/7752736 mongodb修改器(\(inc/\)set/\(unset/\) ...

  8. [转载]MongoDB的$inc修改器

    MongoDB的$inc修改器相当于编程语言中的 “+=”“$inc”只能用于操作数值类型的数据,包括整数.长整数和双精度浮点数,用于其他类型的数据会导致操作失败. >db.users.find ...

  9. python 全栈开发,Day124(MongoDB初识,增删改查操作,数据类型,$关键字以及$修改器,"$"的奇妙用法,Array Object 的特殊操作,选取跳过排序,客户端操作)

    一.MongoDB初识 什么是MongoDB MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介 ...

随机推荐

  1. Jenkins版本升级

    前言 我们的内网打包环境目前是运行在windows上,采用jenkins.msi 安装成windwos服务的形式. 升级前准备 在jenkins版本升级之后,我使用ThinBackup进行了备份,详细 ...

  2. js获取select选中的内容

    ### 获取select选中的内容 js获取select标签选中的值 var obj = document.getElementById("selectId");//获取selec ...

  3. JavaScript -- 时光流逝(六):js中的正则表达式 -- RegExp 对象

    JavaScript -- 知识点回顾篇(六):js中的正则表达式 -- RegExp 对象 1. js正则表达式匹配字符之含义      查找以八进制数 规定的字符.     查找以十六进制数 规定 ...

  4. python mysql数据库操作

    一.pymysql 模块安装(本文博客推荐:https://www.cnblogs.com/clschao/articles/10023248.html) pip3 install pymysql 二 ...

  5. 超简单的gif图制作工具

    测试成功了: 软件灵者Gif录制1.0 使用方法注意: 扩展: 安卓端想要制作gif可参考此方法(还没测试):https://blog.csdn.net/u012604745/article/deta ...

  6. SQL 简介

    SQL 是用于访问和处理数据库的标准的计算机语言. 什么是 SQL? SQL 指结构化查询语言 SQL 使我们有能力访问数据库 SQL 是一种 ANSI 的标准计算机语言 编者注:ANSI,美国国家标 ...

  7. Insert Into 语句的语法错误

    错误示意: 一开始程序是: 改正: 一条很简单的插入语句竟然会报错,然而直接在数据库的查询中执行中却没有问题,这个问题困扰了不少时间. 数据库使用的是ACCESS,INSERT INTO语句为inse ...

  8. apache和nginx结合使用

    1  有时候我们希望将nginx和apache结合起来使用,nginx接受用户的请求,作为请求转发服务器,apache作为后端服务器. 2 配置如下 nginx 中将80端口的请求转发到8000端口上 ...

  9. maven-resources-plugin插件关于占位符不生效问题

    插件版本: <plugin> <artifactId>maven-resources-plugin</artifactId> <version>3.0. ...

  10. 钉钉自定义机器人 发送文本 换行 \n无效果

    今天用php做钉钉自定义机器人 发送文本 换行 \n无效果,原来是我一直用单引号作为定义字符串,换成双引号就ok了.