MongoDB对Document(文档)的插入、删除及更新

一.Document数据插入

1.插入文档

db.[文档名].insert({BSON数据})

2.批量插入文档

shell当中不支持批量插入,想完成批量插入操作,可以使用shell的for循环,或者其他高级语言当中的批量操作方法

例:使用for循环插入10个学生,在学生集合当中

我使用的是2.6的版本,发现已经支持了批量插入操作。

3.Save操作

save操作和insert操作的区别在于,save在遇到_id相同的插入数据时候,会覆盖原来的,而insert会提示错误

例子:

用insert的方法去插入一个_id相同的数据

二.Document数据删除

1.删除列表中所有数据

db.[文档名].remove({})

集合的本身和索引不会别删除

例子:删除列表中所有数据

2.根据条件删除

例: 删除_id为10的那条记录

三.Document数据更新

1.直接覆盖更新

db.[文档名].update({查询器},{修改器})

{查询器}就相当于是条件

{修改器}就是你要直接覆盖替换的BSON数据

例:更新_id为9,那个学生,把Name变成age

注意:当主键冲突的时候会报错并且停止更新操作

例:我用_id为8的数据,去替换_id为9的记录,因为_id为8的数据已经存在,不允许有两个主键为_id:8

的记录,所以会报错。

2.采用insertOrUpdate的做法进行更新

db.[文档名].update({查询器},{修改器},true)

后面第三个参数为true,就代表是当记录不存在的时候,就插入一条记录,如果存在就更新

例:更新一个_id为10的数据,没有就插入,有就更新

3.批量更新操作

db.[文档名].update({查询器},{修改器},false, true)

※默认情况当查询器查询出多条数据的时候默认就修改第一条数据

先修改一下数据如下:

让_id为9和10的数据,有相同的内容

再插入一个_id=11,age=20的数据

第四个参数不写的情况下去更新:

如下:只能更新第一个age=20的数据

第四个参数添加并且为true的时候,我们预期是10和11都能被修正

但是当我试图去更新的时候,报错了,提示说批量更新只能在有$操作的时候使用

修正插入语句

这里注意$set后面要有":",而且它和它后面的修改器要被{}包起来,因为我第一次使用mongoDB,所以总写错。

4.使用修改器来完成局部更新操作

$set它用来指定一个键值对,如果存在键就进行修改不存在则进行添加

{$set:{field:value}}

_id为10的数据,没有Name属性,进行了添加,有age键,就进行了修改

$inc

1.适用于数字类型

2.能够对键对应的数字类型数值进行加减操作

{$inc:{field:value}}

给age=30的数据增加2岁,由于没有使用批量更新参数,所以默认修正了第一条

$unset删除指定的键

{$unset:{field:1}}

我在例子里面先是删除了age=30的数据的age属性,但是有一点不明白,unset后面那个field:1是什么,于是我查了一下,说是后面是什么都无所谓,unset只看键不看value,于是又做了第二个例子

$push

1.如果指定的键是数组增追加新的数值

2.如果指定的键不是数组则中断当前操作,报错

3.如果不存在指定的键则创建数组类型的键值对

{$push:{field:value}}

$pushAll

用法同上,是批量添加数组数据的操作

{$pushAll:{field:array}}

1.第一个操作没有用$pushAll,所以把["C#","JAVA"]当成一个数组项目处理了

2.第二个操作使用了$pushAll,所以当成了两项来处理的。

$addToSet

往数组中添加项目,存在就不添加,不存在就添加(push不管存不存在都添加)

{$addToSet:{field:value}}

1.先用push插入,发现更新完成后有两个“C#”

2.再用addToSet更新,发现没有增加项目

$pop

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

{$pop:{field:value}}

1.删除最后一个索引位置的数据,后面的value用"1"

2.删除第一位置索引的数据,value=-1

$pull

push的逆向操作,删除键是数组的项目中的指定元素

{$pull:{field:value}}

$pullAll

批量删除数组中的指定元素

{$pullAll:{field:array}}

$ 数组定位器,如果数组有多个数值我们只想对其中一部分进行操作我们就要用到定位器($)

{$push:{field:value}}

1.实例第一个是在刚刚清空的数组里面添加了两个元素

2.我想在{“SubID”:1,"SubName":"MangoDB"}这个对象里面再添加"Teacher":"Lucy"

5.$addToSet与$each结合完成批量数组更新

理解:首先从上面的例子中我们知道,addToSet这个修改器,可以判断是否项目存在,不存在的时候就直接插入。

此时我有一个功能,例如我想往一个存在数据的数组中批量更新数据,如果存在就不更新。那么只使用addToSet是不能进行批量的,于是就要结合$each来实现。

例:

1.新创建一个文件,并使用pushAll修改器添加数据:

2.我想要批量插入"C#","PHP","JavaScript","JAVA",要求不能有重复的

如果这时候我直接用pushAll来进行更新的话,"C#"和"JAVA"就会有重复

在shell当中输入如下命令:

总结:以上就是MongoDB的Document的插入、删除以及更新的使用。

到此这篇关于MongoDB操作Document的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • 使用MongoDB操作文档

    目录 一.插入文档 1.使用insert()方法插入文档 2.使用save()方法插入文档 二.查询文档 1.语法 2.实例 3.MongoDBAND条件查询 4.MongoDBOR条件查询 三.更新文档 1.update()方法 2.save()方法 四.删除文档 1.删除title为MongoDB教程的文档,只删除一个: 2.删除所有数据 本篇文章中将讲解如何使用MongoDB操作文档. 文档的数据结构和JSON基本一致,所有存储在集合中的数据都是BSON格式.BSON是一种类似json格式

  • MongoDB快速入门笔记(六)之MongoDB删除文档操作

    MongoDB是一个跨平台,面向文档的数据库,提供高性能,高可用性和易于扩展.MongoDB是工作在集合和文档上一种概念. 文档是一组键值对.文档具有动态模式.动态模式是指,在同一个集合的文件不必具有相同一组集合的文档字段或结构,并且相同的字段可以保持不同类型的数据. db.集合名称.remove({query}, justOne) query:过滤条件,可选 justOne:是否只删除查询到的第一条数据,值为true或者1时,只删除一条数据,默认为false,可选. 准备数据:把_id为1和2

  • MongoDB快速入门笔记(三)之MongoDB插入文档操作

    MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的. 本文给大家介绍MongoDB的插入文档的方法,一起看看吧 1.文档的数据存储格式为BSON,类似于JSON.MongoDB插入数据时会检验数据中是否有"_id",如果没有会自动生成. shell操作有insert和save两种方法.当插入一条数据有

  • MongoDB快速入门笔记(四)之MongoDB查询文档操作实例代码

    MongoDB简介 MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的. 下面给大家介绍MongoDB查询文档操作的实例 先把student删除,再重新插入数据 > db.student.drop() true > db.student.insert([{ "_id" : 1, "

  • MongoDB中对文档的增删查改基本操作方法总结

    插入文档:insert() 方法 要插入数据到 MongoDB 集合,需要使用 MongoDB 的  insert() 或 save() 方法. 语法: insert() 命令的基本语法如下: >db.COLLECTION_NAME.insert(document) 例子:  >db.mycol.insert({    _id: ObjectId(7df78ad8902c),    title: 'MongoDB Overview',     description: 'MongoDB is

  • MongoDB数据库文档操作方法(必看篇)

    前面的话 本文将详细介绍MongoDB数据库关于文档的增删改查 如果数据库中不存在集合,则MongoDB将创建此集合,然后将文档插入到该集合中 要在单个查询中插入多个文档,可以在insert()命令中传递文档数组 可以使用js语法,插入多个文档 [save()] 插入文档也可以使用db.post.save(document). 如果不在文档中指定_id,那么save()方法将与insert()方法一样自动分配ID的值.如果指定_id,则将以save()方法的形式替换包含_id的文档的全部数据.

  • MongoDB基础之文档操作

    一.插入文档 文档的数据结构和 JSON 基本一样. 所有存储在集合中的数据都是 BSON 格式.BSON 是一种类似 JSON 的二进制形式的存储格式,是 Binary JSON 的简称. 1.语法 1.db.collection.insert(): 向集合中插入文档,若插入的数据主键已经存在,则会抛 org.springframework.dao.DuplicateKeyException 异常,提示主键重复,不保存当前数据. db.collection.insert(document) 2

  • MongoDB中文档的更新操作示例详解

    前言 在MongoDB中,更新单个doc的操作是原子性的.默认情况下,如果一个update操作更新多个doc,那么对每个doc的更新是原子性的,但是对整个update 操作而言,不是原子性的,可能存在前面的doc更新成功,而后面的doc更新失败的情况.由于更新单个doc的操作是原子性的,如果两个更新同时发生,那么一个更新操作会阻塞另外一个,doc的最终结果值是由时间靠后的更新操作决定的. 我们在前面的文章中提到过文档的基本的增删改查操作,MongoDB中提供的增删改查的语法非常丰富,不清楚的朋友

  • MongoDB快速入门笔记(六)之MongoDB的文档修改操作

    MongoDB MongoDB 是一个开源的文档数据库,并领先的 NoSQL 数据库. MongoDB 是由 c++语言编写. 文档 文档是一组键 - 值对.文件动态模式.动态模式是指,在相同集合中的文档不需要具有相同的字段或结构组的公共字段的集合的文档,可以容纳不同类型的数据. db.集合名称.update({query},{update},upsert, multi}) query:过滤条件 update:修改内容 upsert:如果不存在查询条件查出的记录,是否插入一条数据,默认是fals

  • Java如何操作MongoDB常用API文档

    目录 Java操作MongoDB常用API文档 1.查询指定字段 2.按条件查询 3.对查询结果排序 4.获取满足条件的前n条数据 Java使用MongoDB数据库相关API小记 MongDB数据库使用 首先介绍我的使用环境 Java操作MongoDB常用API文档 1.查询指定字段 collection.find().projection(fields(include("username","pwd"),excludeId()));//返回username与pwd

  • JavaScript中的Document文档对象

    Document文档对象是JavaScript中window和frames对象的一个属性,是显示于窗口或框架内的一个文档.描述当前窗口或指定窗口对象的文档.它包含了文档从<head>到</body>的内容. 用法:document (当前窗口) 或 <窗口对象>.document (指定窗口) 属性: document.title //设置文档标题等价于HTML的<title>标签 document.bgColor //设置页面背景色 document.fg

  • python处理document文档保留原样式

    document文档格式.线段.图片.页眉页脚等都不变,供大家参考,具体内容如下 # -*- coding: utf-8 -*- # @Time : 2019/5/6 11:46 # @Author : """ # 利用python-docx替换文章中的内容 pip install python-docx # 格式.线段.图片.页眉页脚等都不变 # python-docx 在处理超链接的问题时,可以参考一下链接对源码进行修改 https://github.com/python

  • JS document文档的简单操作完整示例

    本文实例讲述了JS document文档的简单操作.分享给大家供大家参考,具体如下: <html> <head> <title>js-documnent文档结构操作</title> <meta charset="UTF-8"/> <script type="text/javascript"> function testFile(){ // 获取元素 var showdiv=document.ge

  • mongodb如何对文档内数组进行过滤的方法步骤

    本文介绍了mongodb如何对文档内数组进行过滤的方法步骤,分享给大家,具体如下: mongodb文档内包含数组,需要将数组中符合条件的数据过滤出来并返回结果集,可以用两种方式来查询group或filter. 数据源: { "_id" : ObjectId("5bbcc0c9a74db9804e78a157"), "uid" : "1000001", "name" : "zhangsan"

  • python对文档中元素删除,替换操作

    pthon更换文档中某元素: with open('E:\\桌面\\train.txt', 'r') as f:     lines = f.readlines() ​ with open('E:\\桌面\\1704.txt', 'a') as ff: # 此处 w 和 a,均可,反正是新建的临时文件,文件不存在时会自动创建     for line in lines:         # kv = line.strip().split(' ')         kv = line.split(

  • PostgreSQL数据库事务插入删除及更新操作示例

    目录 INSERT DELETE UPDATE 事务 INSERT 使用INSERT语句可以向表中插入数据. 创建一个表: CREATE TABLE ProductIns (product_id CHAR(4) NOT NULL, product_name VARCHAR(100) NOT NULL, product_type VARCHAR(32) NOT NULL, sale_price INTEGER DEFAULT 0, purchase_price INTEGER , regist_d

  • PHP库 查询Mongodb中的文档ID的方法

    在IBM我的一份新工作是一名开发的后勤人员.那意味着我的大部分时间是在和数据库打交道.在我的工作流程中,我花了一些时间在MongoDB上面--这是一个文档数据库.但是在通过ID来检索记录这个操作上面我碰到了一些问题.下面的代码是最终版本,以后碰到类似的问题我可以直接引用它.如果大家也需要,希望下面对大家有所帮助. MongoDB 和 IDs 当我向一个集合中插入数据的时候,我并没有设置_id字段:如果这个字段是空的话,那么MongoDB将要自动生成一个ID来使用,这对我来说是非常不错的.然而,当

随机推荐