MongoDB 插入文档

文档的数据结构和JSON基本一样。

所有存储在集合中的数据都是BSON格式。

BSON是一种类json的一种二进制形式的存储格式,简称Binary JSON。

插入文档

MongoDB 使用 insert() 或 save() 方法向集合中插入文档,语法如下:

db.COLLECTION_NAME.insert(document)

  插入时如果没有指定文档的Object ID,MongoDB会指定唯一的ObjectID。 

  如果集合不存在,mongodb会自动创建集合。

例如:

> show dbs    #显示所有数据库
exam .078GB
local .078GB
test .078GB
> db.colle1.insert({"name":"qlq","age":}) #插入文档
WriteResult({ "nInserted" : })
> show dbs    #显示所有数据库
exam .078GB
local .078GB
test .078GB
> db #查看当前数据库
test
> show tables  #查看所有集合
colle1
runoob
system.indexes
test

也可以将文档定义为一个变量之后存进去:

> document=({title:"test"})  #定义变量
{ "title" : "test" }
> db.colle1.insert(document)  #将变量存进去
WriteResult({ "nInserted" : })
>

插入文档你也可以使用 db.col.save(document) 命令。如果不指定 _id 字段 save() 方法类似于 insert() 方法。如果指定 _id 字段,则会更新该 _id 的数据。

3.2 版本后还有以下几种语法可用于插入文档:

  • db.collection.insertOne():向指定集合中插入一条文档数据
  • db.collection.insertMany():向指定集合中插入多条文档数据
> var document = db.collection.insertOne({"a": })
> document
{
"acknowledged" : true,
"insertedId" : ObjectId("571a218011a82a1d94c02333")
} # 插入多条数据
> var res = db.collection.insertMany([{"b": }, {'c': }])
> res
{
"acknowledged" : true,
"insertedIds" : [
ObjectId("571a22a911a82a1d94c02337"),
ObjectId("571a22a911a82a1d94c02338")
]
}

MongoDB 查询文档

> show tables
system.indexes
> db.colle1.insert({name:'qlq',age:})
WriteResult({ "nInserted" : })
> show collections
colle1
system.indexes
> db.colle1.find()
{ "_id" : ObjectId("5ab458e7bf43055cd737bd8e"), "name" : "qlq", "age" : }

  发现mongodb自动给维护了一个ObjectID

1.简单查询

db.colle1.find()

再次插入一条查询:

> db.colle1.insert({name:'wjy',age:})
WriteResult({ "nInserted" : })
> db.colle1.find()
{ "_id" : ObjectId("5ab458e7bf43055cd737bd8e"), "name" : "qlq", "age" : }
{ "_id" : ObjectId("5ab45dd7bf43055cd737bd8f"), "name" : "wjy", "age" : }

MongoDB 更新文档

MongoDB 使用 update() 和 save() 方法来更新集合中的文档。接下来让我们详细来看下两个函数的应用及其区别。

update() 方法

update() 方法用于更新已存在的文档。语法格式如下:

db.collection.update(
<query>,
<update>,
{
upsert: <boolean>,
multi: <boolean>,
writeConcern: <document>
}
)

参数说明:

  • query : update的查询条件,类似sql update查询内where后面的。
  • update : update的对象和一些更新的操作符(如$,$inc...)等,也可以理解为sql update查询内set后面的
  • upsert : 可选,这个参数的意思是,如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
  • multi : 可选,mongodb 默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。
  • writeConcern :可选,抛出异常的级别。

修改单个:

> db.colle1.find()
{ "_id" : ObjectId("5ab458e7bf43055cd737bd8e"), "name" : "qlq", "age" : }
{ "_id" : ObjectId("5ab45dd7bf43055cd737bd8f"), "name" : "wjy", "age" : }
> db.colle1.update({},{name:'qlq1'})
WriteResult({ "nMatched" : , "nUpserted" : , "nModified" : })
> db.colle1.find()
{ "_id" : ObjectId("5ab458e7bf43055cd737bd8e"), "name" : "qlq1" }
{ "_id" : ObjectId("5ab45dd7bf43055cd737bd8f"), "name" : "wjy", "age" : }

解释;

db.colle1.update({},{name:'qlq1'}) 语句的query语句虽然没有写,会查到所有数据,但是只会修改第一条数据。而且update帮我们把整个文档替换了,只有objectid没有变。

解决办法:只修改指定属性而不替换整个文档:

原来数据:

> db.colle1.find()
{ "_id" : ObjectId("5ab460eebf43055cd737bd90"), "name" : "wjy", "age" : }
{ "_id" : ObjectId("5ab460f4bf43055cd737bd91"), "name" : "qlq", "age" : }

修改数据的指定属性:在上面基础上加上{$set:    }

> db.colle1.update({},{$set:{name:'qlq1'}})
WriteResult({ "nMatched" : , "nUpserted" : , "nModified" : })
> db.colle1.find()
{ "_id" : ObjectId("5ab460eebf43055cd737bd90"), "name" : "qlq1", "age" : }
{ "_id" : ObjectId("5ab460f4bf43055cd737bd91"), "name" : "qlq", "age" : }

修改多个:

> db.colle1.update({},{$set:{name:'qlq4'}},false,true)
WriteResult({ "nMatched" : , "nUpserted" : , "nModified" : })
> db.colle1.find()
{ "_id" : ObjectId("5ab460eebf43055cd737bd90"), "name" : "qlq4", "age" : }
{ "_id" : ObjectId("5ab460f4bf43055cd737bd91"), "name" : "qlq4", "age" : }

  修改多个需要使用$set,且设置multi的值为true。

save() 方法

save() 方法通过传入的文档来替换已有文档。如果不存在就添加数据,如果存在就替换数据。语法格式如下:

db.collection.save(
<document>,
{
writeConcern: <document>
}
)

参数说明:

  • document : 文档数据。
  • writeConcern :可选,抛出异常的级别。

实例

1.save保存不存在的数据:

> db.colle1.find()
{ "_id" : ObjectId("5ab460eebf43055cd737bd90"), "name" : "qlq4", "age" : }
{ "_id" : ObjectId("5ab460f4bf43055cd737bd91"), "name" : "qlq4", "age" : }
> db.colle1.save({name:'qlq',age:})
WriteResult({ "nInserted" : })
> db.colle1.find()
{ "_id" : ObjectId("5ab460eebf43055cd737bd90"), "name" : "qlq4", "age" : }
{ "_id" : ObjectId("5ab460f4bf43055cd737bd91"), "name" : "qlq4", "age" : }
{ "_id" : ObjectId("5ab463d6bf43055cd737bd92"), "name" : "qlq", "age" : }

2.传入ObjectId修改已经存在的数据:

> db.colle1.save({"_id":ObjectId("5ab463d6bf43055cd737bd92"),name:'qlq44',age:})
WriteResult({ "nMatched" : , "nUpserted" : , "nModified" : })
> db.colle1.find()
{ "_id" : ObjectId("5ab460eebf43055cd737bd90"), "name" : "qlq4", "age" : }
{ "_id" : ObjectId("5ab460f4bf43055cd737bd91"), "name" : "qlq4", "age" : }
{ "_id" : ObjectId("5ab463d6bf43055cd737bd92"), "name" : "qlq44", "age" : }

更多实例

只更新第一条记录:

db.col.update( { "count" : { $gt :  } } , { $set : { "test2" : "OK"} } );

全部更新:

db.col.update( { "count" : { $gt :  } } , { $set : { "test2" : "OK"} },false,true );

只添加第一条:

db.col.update( { "count" : { $gt :  } } , { $set : { "test5" : "OK"} },true,false );

全部添加加进去:

db.col.update( { "count" : { $gt :  } } , { $set : { "test5" : "OK"} },true,true );

全部更新:

db.col.update( { "count" : { $gt :  } } , { $inc : { "count" : } },false,true );

只更新第一条记录:

db.col.update( { "count" : { $gt :  } } , { $inc : { "count" : } },false,false );

MongoDB 删除文档

MongoDB remove()函数是用来移除集合中的数据。

MongoDB数据更新可以使用update()函数。在执行remove()函数前先执行find()命令来判断执行的条件是否正确,这是一个比较好的习惯。

语法

remove() 方法的基本语法格式如下所示:

db.collection.remove(
<query>,
<justOne>
)

如果你的 MongoDB 是 2.6 版本以后的,语法格式如下:

db.collection.remove(
<query>,
{
justOne: <boolean>,
writeConcern: <document>
}
)

参数说明:

  • query :(可选)删除的文档的条件。
  • justOne : (可选)如果设为 true 或 1,则只删除一个文档。
  • writeConcern :(可选)抛出异常的级别。

实例

删除单个:

> db.colle1.find()
--23T10::40.696+ I NETWORK trying reconnect to 127.0.0.1: (127.0.0.1) failed
--23T10::40.696+ I NETWORK reconnect 127.0.0.1: (127.0.0.1) ok
{ "_id" : ObjectId("5ab460eebf43055cd737bd90"), "name" : "qlq4", "age" : }
{ "_id" : ObjectId("5ab460f4bf43055cd737bd91"), "name" : "qlq4", "age" : }
{ "_id" : ObjectId("5ab463d6bf43055cd737bd92"), "name" : "qlq44", "age" : }
> db.colle1.remove({name:'qlq44'},{justOne:true}) #删除单个
WriteResult({ "nRemoved" : })
> db.colle1.find()
{ "_id" : ObjectId("5ab460eebf43055cd737bd90"), "name" : "qlq4", "age" : }
{ "_id" : ObjectId("5ab460f4bf43055cd737bd91"), "name" : "qlq4", "age" : }

如果不指定justOne会删除符合条件的多个:

> db.colle1.find()
{ "_id" : ObjectId("5ab46bbeeee8eb99039a98e4"), "name" : "qlq3", "age" : 25, "sex" : "男" }
{ "_id" : ObjectId("5ab46bc9eee8eb99039a98e5"), "name" : "qlq4", "age" : 25, "sex" : "男" }
{ "_id" : ObjectId("5ab46bd6eee8eb99039a98e6"), "name" : "qlq4", "age" : 26, "sex" : "男" }
> db.colle1.remove({name:"qlq4"})
WriteResult({ "nRemoved" : 2 })
> db.colle1.find()
{ "_id" : ObjectId("5ab46bbeeee8eb99039a98e4"), "name" : "qlq3", "age" : 25, "sex" : "男" }

删除所有:

> db.colle1.find()
{ "_id" : ObjectId("5ab460eebf43055cd737bd90"), "name" : "qlq4", "age" : }
{ "_id" : ObjectId("5ab460f4bf43055cd737bd91"), "name" : "qlq4", "age" : }
> db.colle1.remove({})             #删除所有
WriteResult({ "nRemoved" : })
> db.colle1.find()

mongoDB文档操作【增删改】的更多相关文章

  1. MongoDB文档的增删改操作

    上一篇文章中介绍了MongoDB的一些基本知识,同时看到了怎么启动一个MongoDB服务,并且通过MongoDB自带的shell工具连接到了服务器. 这一次,就通过MongoDB shell介绍一下对 ...

  2. Elasticsearch之文档的增删改查以及ik分词器

    文档的增删改查 增加文档 使用elasticsearch-head查看 修改文档 使用elasticsearch-head查看 删除文档 使用elasticsearch-head查看 查看文档的三种方 ...

  3. mongoDB 文档操作_删

    mongoDB 文档删除 MySQL对比 mysql delete from table where ... mongo db.collection.deleteOne(query) 删除函数 del ...

  4. mongodb对数组元素及内嵌文档进行增删改查操作(转)

    from:https://my.oschina.net/132722/blog/168274 比如我有一个user类,他包含一个标签属性,这个标签是一个数组,数组里面的元素是内嵌文档,格式如下: &l ...

  5. MongoDB对数组元素及内嵌文档进行增删改查操作

    比如我有一个user类,他包含一个标签属性,这个标签是一个数组,数组里面的元素是内嵌文档,格式如下: {    "_id" : "195861",    &qu ...

  6. Mongodb的基本操作-数据库 集合 文档的增删改查

    数据库操作: //查看有哪些数据库 > show dbs local  0.078GB mydb   0.078GB //use操作将切换到一个数据库 如果数据库存在将直接切换 如果不存在 那么 ...

  7. 对mongo文档的增删改操作

    在mongo db 中增加.删除.修改文档有好多方法,这里简单记录一下我所知道的一些方法. 前置条件: 1.创建study数据库  use study; 2.创建persons集合,当第一次向pers ...

  8. mongoDB 文档操作_增

    增加 / 插入 /保存 单文档插入 命令 db.collection.insertOne(doc) 功能 向被 use 的数据库中插入数据 实例 db.class.insertOne({"n ...

  9. 分布式搜索elasticsearch 索引文档的增删改查 入门

    1.RESTful接口使用方法 为了方便直观我们使用Head插件提供的接口进行演示,实际上内部调用的RESTful接口. RESTful接口URL的格式: http://localhost:9200/ ...

随机推荐

  1. 虚拟现实-VR-UE4-创建第一个C++项目——Hello word

    这部分主要是调用在C++中用代码实现在游戏界面上面输出一行文字 第一步,新建C++版本的工程文件,在4.12版本以后,在创建后,都会自动打开Vs编译器. 如下图 在VS中点击编译,等带编译,第一次等待 ...

  2. #Spring实战第二章学习笔记————装配Bean

    Spring实战第二章学习笔记----装配Bean 创建应用对象之间协作关系的行为通常称为装配(wiring).这也是依赖注入(DI)的本质. Spring配置的可选方案 当描述bean如何被装配时, ...

  3. N-grams模型、停顿词(stopwords)和标准化处理 - NLP学习(2)

    在上一节<Tokenization - NLP(1)>的学习中,我们主要学习了如何将一串字符串分割成单独的字符,并且形成一个词汇集(vocabulary),之后我们将形成的词汇集合转换成计 ...

  4. tensorflow学习笔记(1)-基本语法和前向传播

    tensorflow学习笔记(1) (1)tf中的图 图中就是一个计算图,一个计算过程.                                       图中的constant是个常量 计 ...

  5. 日历插件DatePicker

    Datepicker 地址:https://getuikit.com/v2/docs/datepicker.html

  6. scp源码浅析

    背景: 经常使用scp传文件,发现它真的很给力,好奇心由来已久! 恰好接到一个移植SSH服务到专有网络(非IP网络)的小任务,完成工作又能满足好奇心,何乐而不为! 我只从源码浅浅的分析一下,后续有更多 ...

  7. PokeCats开发者日志(一)

      现在是PokeCats游戏开发的第三天的上午,突然心血来潮想记录一下这个开发过程,于是写起了开发者日志. day1   作为一只ACM退役喵,寒假回家,闲着没事,天天在召唤师峡谷里闲逛也挺没意思的 ...

  8. 算法(1)K-diff Pairs in an Array

    写在前面:研究操作系统,习惯了用C,但是在做算法题甚至构建大型系统时,C真的是噩梦.还是用C++比较好,基本算法很成熟,并可基于此实现更复杂的算法.那就边写算法边捡起来好久不用的C++吧! 题目:数组 ...

  9. 【bzoj5060】魔方国 乱搞+特判

    题目描述 一张未知的有重边无自环的图,只知道点数为n,边数为m.可以标记若干个点,如果一个点被标记,那么与它距离不超过k的点(包括本身)都会被覆盖. 显然对于每张不同图,让所有点被覆盖的最小代价是不一 ...

  10. 【bzoj1263】[SCOI2006]整数划分 高精度

    题目描述 从文件中读入一个正整数n(10≤n≤31000).要求将n写成若干个正整数之和,并且使这些正整数的乘积最大. 例如,n=13,则当n表示为4+3+3+3(或2+2+3+3+3)时,乘积=10 ...