创建、更新、删除文档。 --- Mongodb权威指南阅读。

插入文档:

  db.foo.insert({ "key" : "value"});

  使用insert插入一个数据,文档中如果没有_id 会自动给文档增加_id.

  batchInsert(Array)  批量插入,接受一个文档数组做参数。

    使用批量插入最大长度48M,如果过程中一个失败,失败之前会插入成功,之后全都失败。

    可以设置continueOnError 选项设置忽略错误并且继续插入。

  插入校验: 所有文档必须都小于16M。

删除文档:

  db.foo.remove();

    上述命令会删除foo集合中所有文档,不会删除集合本身,也不会删除集合的元信息。remove可以接受一个查询文档作为可选参数。

    删除是永久性的,不可以撤消,也不能恢复。

    删除文档通常很快,但是要清空整个集合,使用drop直接删除集合,再从空集合上重建各项索引会更快。

更新文档:

  db.user.update(参数1,参数2)

  第一个参数查询文档,第二个参数修改器文档。

    常见错误,查问文档匹配多个文档,更新时第二个参数产生了重读的_id 值,数据库会抛出错误。任何文档都不会更新。

      使用_id查询比使用随机字段速度快,因为通过_id建立的索引。

  增加修改或删除键时最好使用修改器,避免替换原文档。

使用修改器:

  $set : 用来指定一个字段的值,如果不存在这个字段,则创建它。  $set可以修改键的类型。 ---->  $unset 删除某个键。

  $inc : 用来增加已有键的值,如果不存在就创建一个。 $inc 只能操作整型,长整型,或者双精度浮点型的值。 $inc 的值 必须为数字。

  $push :  向以后数组末尾加入一个元素,如果没有就创建一个新的数组。

  $each : 遍历数组, 可以配合$push 操作添加多个值。

  $slice :  设置数组最大长度, $slice 的值必须是负整数。 $slice 和 $push 组合使用 可以保证数组不会超过设定的最大长度。

  $sort : 清理数据

  $ne :  保证数组内的元素不会重复。

  $addToSet : 如果文档不存在,就添加进去。

  $pop : 可以从数组的任何一端删除元素。 {"$pop" : {"key" : 1}} 从数组末尾删除。 {"$pop" : {"key" : -1}}  从数组头部删除。

  $pull :  基于特定条件来删除元素。 $pull 会讲所有匹配到的文档删除。

  $ : 基于位置的数组修改器。 用来定位查询文档已经匹配的数组元素,并进行更新。

    db.blog.update({ "comments.author" : "jhon"},

      ... {"$set" : {"comments.$.author" : "jim"}})

 upsert :  如果没找到符合更新条件的文档,就以条件文档和更新文档,创建一个新的文档。

  默认情况,更新智能对符合条件的第一个文档执行操作。如果有多个文档符合条件,只有第一个文档回被更新。 如果匹配所有文档需要将update 第四个参数设置为true。

findAndModify : 在一个造作中返回匹配的结果,并进行更新。

  可选字段:

    findAndmodify : 字符串,集合名。

    query : 查询文档。

    sort : 排序的结果条件。

    update : 修改器文档。

    remove : 布尔类型,表示是否删除文档。

    new :  布尔类型, 表示返回更新前的文档还是更新后的文档。默认是更新前的文档。

    fields : 文档中需要返回的字段。

    upsert : 布尔类型, 当true是 表示这是一个upsert 默认为false。

  

  

  

时间: 2024-10-13 19:52:51

创建、更新、删除文档。 --- Mongodb权威指南阅读。的相关文章

MongoDB创建\更新\删除文档操作

?? 一.插入\创建文档 --当插入一个不存在的文档时,会自动创建一个文档 [[email protected] ~]# mongo MongoDB shell version: 2.4.14 connecting to: test > show collections > db.cols.insert({bar:"baz"}) > db.cols.find() { "_id" :ObjectId("56aac1df4e61b6d9f84

MongoDB(二)创建更新删除文档

插入并保存文档操作 用insert向目标集合插入文档,如果没有_id键则会自动添加.最后自动保存. >db.foo.insert({"bar":"baz"}) 如果要批量插入怎么办呢,看下面代码: >db.foo.insert([{"_id":0},{"_id":1},"{"_id":2}]) 以前有一个batchInsert函数,现在已经没有了.注意在批量插入的过程中如果有一个文档插

大数据技术之_20_Elasticsearch学习_01_概述 + 快速入门 + Java API 操作 + 创建、删除索引 + 新建、搜索、更新删除文档 + 条件查询 + 映射操作

一 概述1.1 什么是搜索?1.2 如果用数据库做搜索会怎么样?1.3 什么是全文检索和 Lucene?1.4 什么是 Elasticsearch?1.5 Elasticsearch 的适用场景1.6 Elasticsearch 的特点1.7 Elasticsearch 的核心概念1.7.1 近实时1.7.2 Cluster(集群)1.7.3 Node(节点)1.7.4 Index(索引 --> 数据库)1.7.5 Type(类型 --> 表)1.7.6 Document(文档 -->

REST API (更新删除文档)

Elasticsearch的更新文档API准许通过脚本操作来更新文档.更新操作从索引中获取文档,执行脚本,然后获得返回结果.它使用版本号来控制文档获取或者重建索引. 我们新建一个文档: 请求:PUT http://localhost:9200/test/type1/1?pretty 参数: { "counter" : 1, "tags" : ["red"] } 脚本开启功能 在最新版本的Elasticsearch中,基于安全考虑(如果用不到,请保

Mongodb基础知识----Mongodb权威指南阅读

文档是Mongodb中数据的基本单元,类型关系型数据库中的行,每个文档都有一个键值唯一的键_id.集合可以看做拥有动态模式的表. Mongodb一个实例可以拥有多个相互独立的数据库. Mongodb区分类型,区分大小写,文档中内容不能有重复的键,文档中的键值对是有序的. 集合名: 集合名不能是空字符串,不能包含\0字符,这表示集合名结束. 集合名不能已system.开头,这是系统集合保留的前缀. 集合名不能包含保留字符. 数据库名: 不能是空字符串,基本上只能使用ASSCII中的字母和数字.库名

MongoDB创建、更新及删除文档

1.1插入并保存文档 插入是向MongoDB中添加数据的基本方法.对目标机使用insert方法,插入一个文档: > db.foo.insert({"bar" : "baz"}) 这个操作会给文档增加一个"_id"键(要是原来没有的话),然后将其保存到MongoDB中. 1.1.1 批量插入 如果要插入多个文档,使用批量插入会快一些.批量插入能传递一个由文档构成的数组给数据库.只有插入多个文档到一个集合的时候,这种方式才会有用,而不能批量插入

MongoDB学习笔记二:创建、更新及删除文档

插入并保存文档 对目标集使用insert方法插入一个文档: > db.foo.insert({"bar" : "baz"}) 这个操作会给文档增加一个"_id"键(要是原来没有的话),然后将其保存到MongoDB中.批量插入 如果要插入多个文档,使用批量插入会快一些.批量插入传递一个由文档构成的数组给数据库.如果只是导入数据(例如,从数据feed或者MySQL中导入),可以使用命令行工具,如mongoimport,而不是使用批量插入. 删除

MongoDB学习笔记-创建、更新、删除文档

创建 MongoDB中使用insert方法来向集合插入文档,然后保存到MongoDB中. db.foo.insert({“hehe”:”呵呵”}) 如果想批量插入的话可以使用下面这种形式:db.foo.insert([{“hehe”:”呵呵”},{“haha”:”哈哈”}]) 插入校验 插入数据时MongoDB只对数据进行最基本的检查-检查文档的基本结构.如果没有“_id”字段,就会自动增加一个,所有文档都必须小于16MB(这个值是MongoDB设计者人为定义的,未来可能会增加).这样的限制主要

03.创建、更新和删除文档。

插入: >db.collectionName.insert({"bar":"baz")} 批量插入:如果要向集合插入多个文档,使用批量插入会快一些. batchInsert函数实现批量插入,它接受一个文档数组作为参数. >db.collectionName.batchInsert([ {"_id:0}, {"_id":1}, {"_id":2} ]) >db.collectionName.find(