在前一篇中简单的介绍了一些基本操作命令,现在分别针对这些命令进行比较详细的说明:


一、数据插入

  插入数据使用命令insert,insert的参数只有一个,就是要插入的文档BSON数据。MongoDB的shell客户端没有提供批量插入的api,如果需要批量插入,那么需要使用javascript脚本来插入数据。

db.users.insert({name:"tom",pwd:"123",sex:"m"})                     #### 单独的插入数据
for(var i=0;i<100;i++){db.users.insert({name:"tom"+i,pwd:""+i})} #### 批量插入数据

  除了使用insert可以插入数据外,使用save命令也可以插入数据,save也只有一个参数。

db.users.save({_id:ObjectId("012345678901234567890123"),name:"lili"})

  save和insert的区别:当遇到唯一索引key相同的情况下,save操作是进行强制更新,就是删除在重建,但是insert会报错。

db.users.insert({_id:ObjectId("012345678901234567890123"),name:"lili2",pwd:"123"})  #### 会出现异常,E11000 duplicate key error index
db.users.save({_id:ObjectId("012345678901234567890123"),name:"lili2",pwd:"123"})

二、删除文档

  删除文档只有命令remove,remove有且只有一个参数,remove方法会删除匹配的所有文档。如果当需要删除集合中的所有文档数据的时候,建立直接使用drop方法。

db.users.remove({name:"lili2"})    ### 删除姓名为lili2的user

三、更新文档

  更新文档命令为update,update方法参数格式为:

db.[collectionName].update(查询器,更新器,是否插入,是否批量)

  默认情况下,更新操作只有当查询器查到数据后,才会更新,那么可以设置当不存在数据则插入(第三个参数为true);更新操作只更新第一个匹配的记录,可以设置第四个参数为true进行批量更新。

  如果在更新器中我们不使用修改器,那么进行的是强制更新,即先删除在添加的操作(一条记录),而且如果使用第四个参数,那么必须使用修改器即:

db.users.update({name:"lili"},{age:23})    #### 结果是修改的记录没有了其他的属性,只有age。
db.users.update({name:"lili"},{$set:{age:23}}) #### 正常,添加一个age

  常用修改器:

修改器名称

语法

案例

$set

{$set:{field:value[,field2:value2....]}}

db.users.update({},{$:{name:1}})

$set用来指定一个键值对,如果键存在就进行修改,如果不存在,那么进行插入。

$inc

{$inc:{field:value}}

db.users.update({},{$inc:{age:1}})

$inc只能与数字类型结合使用,作用是为指定键对应的数字类型的数值添加/或者减少操作。

$unset

{$unset:{field:1}}

db.users.update({},{$unset:{email:1}})

删除指定键

$push

{$push:{field:value}}

db.users.update({},{$push:{books:””}})

1、如果指定的键是数组,则追加value到数组中去。
2、如果指定的键不是数组,那么中断当前操作Cannot apply $push/$pushAll modifier to non-array

3、如果不存在指定键,那么新建一个指定键的数组键值对

$pushAll

{$pushAll:{field:array}}

db.users.update({},{$push:{books:[]}})

用法和push一样,插入全部数据

$addToSet

{$addToSet:{field:value}}

db.users.update({},{$addToSet:{ips:”127.0.0.1”}})

如果键不存在,则创建。如果键存在,那么判断指定的value是否在值中,如果在,那么不操作,如果不在,那么添加进入。如果指定的键不是array类型的键,那么中断报错。

$pop

{$pop:{field:value}}

db.users.update({},{$pop:{books:1}})

从指定数组中删除一个值,1表示删除最后一个值,-1表示删除第一个值。

$pull

{$pull:{field:value}}

db.users.update({},{$pull:{books””js”}})

删除一个指定值

$pullAll

{$pullAll:{field:array}}

Db.users.update({},{$pullAll:{books:[“js”,”mongo”]}})

一次删除多个值

$

数组定位器,如果数组有多个数值,但是我们只想将其中一部分数据进行修改,那么我们可能就需要使用到定位器($).

例如:当有文档{name:”YFC”,age:27,books:[{type:’JS’,name:”EXTJS4”},{type:”JS”,name:”JQUERY”},{type:”DB”,name:”MONGODB”}]}我们要把type为JS的文档增加一个相同的作者auth是UPSCAT

办法:

db.users.update({"books.type":"JS"},{$set:{"books.$.author":"uspcat"}})

$each

{$each:array}

$each将array中的元素一个一个的循环拿出,可以到$addToSet修改器配合完成,将不存在的元素添加,存在的元素不添加的功能。即$addToSetAll的功能(不存在这个修改器)。

db.users.update({},{$addToSet:{books:{$each:[{type:"java",name:"spring"},{type:"db",name:"mongodb"}]}}},false,true)

[MongoDB] - 数据的增删改操作的更多相关文章

  1. Elasticsearch2.4.6版本 在linux 命令行 对数据的增删改操作

    一._cluster系列:查询设置集群状态 1.设置集群状态 curl -XGET 10.68.120.167:9204/_cluster/health?pretty=true pretty=true ...

  2. Elasticsearch6.8.6版本 在head插件中 对数据的增删改操作

    一.访问ES方法:http://IP:PORT/ 一.创建索引:head插件创建索引的实例:在"索引"-"新建索引"中创建索引名称,默认了分片与副本情况: 直接 ...

  3. mysql常用基础操作语法(三)~~对数据的增删改操作【命令行模式】

    1.插入单条数据:insert into tablename(字段名1,字段名2,...) values(值1,值2,...); 从图中可以看出,插入时不需要每个字段都有值(在没有相关的约束前提下), ...

  4. (数据科学学习手札126)Python中JSON结构数据的高效增删改操作

    本文示例代码及文件已上传至我的Github仓库https://github.com/CNFeffery/DataScienceStudyNotes 1 简介 在上一期文章中我们一起学习了在Python ...

  5. 【Axure8】利用中继器(Repeater)实现表格数据的增删改

    利用Repeater实现对Table数据的增删改操作. 先拖入必需的控件:rectangle.text field.droplist.button.table.repeater.具体信息如图. 为方便 ...

  6. MySQL增删改操作

    增删改操作 增加 看语法 1. 插入完整数据(顺序插入) 语法一: INSERT INTO 表名(字段1,字段2,字段3-字段n) VALUES(值1,值2,值3-值n); #指定字段来插入数据,插入 ...

  7. Python教程:连接数据库,对数据进行增删改查操作

    各位志同道合的同仁可以点击上方关注↑↑↑↑↑↑ 本教程致力于程序员快速掌握Python语言编程. 本文章内容是基于上次课程Python教程:操作数据库,MySql的安装详解 和python基础知识之上 ...

  8. Python_实现json数据的jsonPath(精简版)定位及增删改操作

    基于python实现json数据的jsonPath(精简版)定位及增删改操作   by:授客 QQ:1033553122 实践环境 win7 64 Python 3.4.0 代码 #-*- encod ...

  9. Oracle.数据的增删改、表操作(创建,修改,删除)、数据类型

    SELECT ename,dname FROM emp,dept WHERE emp.deptno=dept.deptno; SELECT dname,loc FROM dept; SELECT JO ...

随机推荐

  1. .NET反射

    反射是一个程序集发现及运行的过程,通过反射可以得到*.exe或*.dll等程序集内部的信息.使用反射可以看到一个程序集内部的接口.类.方法.字段.属性.特性等等信息.在System.Reflectio ...

  2. STM32驱动DS18B20

    DS18B20 是由 DALLAS 半导体公司推出的一种的“一线总线”接口的温度传感器.与传 统的热敏电阻等测温元件相比,它是一种新型的体积小.适用电压宽.与微处理器接口简单的 数字化温度传感器.一线 ...

  3. 使用Tomcat搭建图片服务器,使图片能够用链接访问

    在后台和前端交互时,遇到了后台存储的图片,前端根据地址无法访问,使用Tomcat搭建图片服务器 1.找到tomcat下的server.xml文件 2.配置文件下加入service节点 <!--为 ...

  4. 重拾python

    前一段碰到几次关于日期计算的题:给出一个日期,计算下一天的日期.虽然不限语言,可是我就C/C++还算熟悉,别的都是刚了解皮毛,根本不会用现成的库啊,无奈啊...只好用c语言一点点实现了,当时真是无比怀 ...

  5. md5-linux_shell

    linux shell提供md5sum用于计算校验MD5值. md5sum - compute and check MD5 message digest md5sum [OPTION]... [FIL ...

  6. 【转】安卓Fragment不完全介绍

    转两篇博客: 1.http://blog.csdn.net/lmj623565791/article/details/37970961 2.http://blog.csdn.net/lmj623565 ...

  7. IOS web app一些实用的属性设置

    IOS对safari私有的属性很多,虽然很多不为人知但是却很实用.掌握好这些属性对web app和混合app的开发会很有帮助. 1.format-detection[telephone=no] 是否自 ...

  8. 三 APPIUM Android自动化 测试初体验

    1.创建一个maven项目 成功新建工程: 编辑pom.xml,在<dependencies></dependencies>下添加appium相关依赖: <depende ...

  9. C#多线程-volatile、lock关键字

    volatile是C#中最简单的一种同步关键字,其意义是针对程序中一些敏感数据,不允许多线程同时访问,保证数据在任何访问时刻,最多有一个线程访问,以保证数据的完整性,虽与java中的synchroni ...

  10. Java线程:线程安全类和Callable与Future(有返回值的线程)

    一.线程安全类 当一个类已经很好的同步以保护它的数据时,这个类就称为线程安全的.当一个集合是安全的,有两个线程在操作同一个集合对象,当第一个线程查询集合非空后,删除集合中所有元素的时候,第二个线程也来 ...