三、MongoDB的创建、更新和删除
三、MongoDB的创建、更新和删除
概要
下面开始学习MongoDB最重要也是最基础的部分:C(创建)R(查询)U(更新)D(删除);由于R(查询)操作相对来说内容比较多,也比较繁琐,
同时使用频率也比较高,所以下一篇会拿出来单独介绍。废话不多说,连上服务器,我们直接进入正题!
一、创建
按照我们关系型数据库的思想,一个服务器要想存放数据,首先要有数据库,表,字段,约束,当然了也少不了主键,外键,索引,关系等;
但是在MongoDB的世界里边,我们不用预先的去创建这些信息从而直接来使用各个属性。
1、数据库(database)
a)、创建
use mydb(创建并切换到名称为mydb的数据库实例下。注:如果你对其不进行任何操作,该数据库是没有任何实际意义的)
2、集合(collection)
a)、创建
我们直接指定,不做任何预处理,指定一个名称为users的数据集(相当于表),并向其中插入一条用户数据。
db.users.insert({ "name" : "wjg" , "age" : 24 })
返回结果如下,表示你已经成功插入了一条数据:
WriteResult({ "nInserted" : 1 })
b)、显式创建
仅创建一个名称为collectionName的,没有任何大小和数量限制的数据集
db.createCollection("collectionName")
如果该数据集有重名,会给出已经存在的提示:
{ "ok" : 0, "errmsg" : "collection already exists", "code" : 48 }
成功之后会给出ok的提示:
{ "ok" : 1 }
3、文档(document)
a)、单一插入
注:如果没有主键“_id”,插入文档的时候MongoDB会为我们自动保存一个进去。
这里我们指定一个“_id”,当然了,“_id”肯定是不能重复的,否则无法插入成功。
db.users.insert({"_id":0,"name":"jack","age":20})
成功插入数据之后:
WriteResult({ "nInserted" : 1 })
b)、批量插入
注:一次性插入多个文档会明显提高插入速度;
插入文档的大小限制为48MB;
如果其中有一个文档插入失败了,这个文档之前的都可以插入成功,但是在它之后都会失败;(不同的驱动可能会有不同的处理方式)
db.users.insert([{"_id":1,"name":"tom","age":21},{"_id":2,"name":"joe","age":22},{"_id":3,"name":"bob","age":22}])
批量插入成功之后会返回如下信息:
BulkWriteResult({
"writeErrors":[],
"writeConcernErrors":[],
"nInserted":3,
"nUpserted":0,
"nMatched":0,
"nModified":0,
"nRemoved":0,
"upserted":[]})
分别表示的大致意思为:
插入的错误信息,其他的插入错误信息,插入的文档数量,特殊更新的文档数量,匹配到的文档数量,
更新的文档数量,移出的文档数量和特殊文档更新信息
特殊的文档更新(upsert),其定义如下:
如果没有找到符合更新条件的文档,就会以这个条件和更新文档为基础创建一个新的文档;如果找到了匹配的文档,那么就正常更新
二、更新
想要更新文档,必须要有两个参数:
一个是查询条件,用于定位到需要更新的目标文档;另一个是修改器,用于说明要对找到的文档进行哪些修改
截至此刻为止,我们已经向mydb数据库中名称为users的数据集中添加了如下几个文档:
a)、单一更新
让我们来为名字为bob的年龄增加一岁,直接将年龄更新为23岁
db.users.update({"name":"bob"},{$set:{"age":23}}) //使用了$set修改器之后,只会更新age自段的值为23
或者
db.users.update({"name":"bob"},{"age":23}) //同样会将age自段的值更新为23,但是会移出除了“_id”和本身之外的所有字段值
具体详情如下图:
注:如果需要更新的字段不存在,那么MongoDB会按字段顺序进行插入,类似于上边提到的特殊更新。
其实细心的童鞋会发现,我们都是以name作为条件进行更新,所以并不能保证其唯一性,那么MongoDB只会更新匹配到的第一个文档。
这里还是建议大家指定一个唯一的文档进行更新,"_id"可以帮你保证!
b)、使用选择器更新(重点)
1、$set修改器
执行特殊更新操作;可以修改内嵌文档;甚至可以更改键的类型;
Ⅰ、假设需求改了,我们需要为为所有用户添加一个”hobby“的属性用于存放用户的喜好,那么我们可以这样做:
db.users.update({},{$set:{"hobby":"read"}}) //这样做是错的,哈哈。。
更新后的文档如下:
切记:update方法只会更新它匹配到的第一个文档对象,所以这个操作只会将名字为”wjg“的用户添加一个”hobby“属性,其它对象不会添加
正确方式如下:
db.users.update({},{$set:{"hobby":"write"}},false,true) //第三个参数为是否启用特殊更新,第四个为是否更新所有匹配的文档;
这俩参数默认都为false
更新后的文档如下:
可以看到我们成功更新了五个文档对象
Ⅱ、假设我们需求又变了,老板说了,每个用户的爱好会有多个。那么简单,因为我们可以直接将string类型的hobby属性改成string数组类型的
db.users.update({"_id":0},{"$set":{"hobby":["write","read","paly ping-pong"]}}) //将_id为0的hobby属性更新为数组类型的
Ⅲ、然后我们发现tom压根就没有爱好,那么我们可以使用$unset修改器将其删除
db.users.update({"_id":1},{"$unset":{"hobby":1}}) //1表示彻底删除这个键值对
Ⅳ、现在已经过去一年了,我们是时候把所有用户的年龄加一岁了。这时$inc上场
db.users.update({},{"$inc":{"age":1}},false,true) //别忘了将第四个参数置为true
注:$inc修改器只针对数字类型,如果是string或者其他类型的会提示报错:
提示无法将$inc应用到非数字类型上,并且给出错误位置:”_id“为2的文档;
我们将joe的age改为数字类型的重新执行一次,就可以成功啦!
Ⅴ、过了一段时间,jack又喜欢上了游泳,那么我们可以用$push这样搞:
db.users.update({"_id":0},{"$push":{"hobby":"swim"}}) //hobby必须是一个数组,所以你在其他文档上使用是不会成功的
Ⅵ、然而jack不喜欢读书了,我们就用$pull来移除“read”元素
db.users.update({"_id":0},{"$pull":{"hobby":"read"}}) //它会移除数组中所有匹配到的“read”元素
另外:db.users.update({"_id":0},{"$pop":{"hobby":1}}) //表示移除hobby中的最后一个元素,为-1表示移除第一个元素
不知道大家有没有发现,“_id”为0的文档从第二的位置被移动到了数据集的末尾,这是因为该文档尺寸变大的原因导致的,
原先的位置已经容不下它了!
那么这就引出了另外一个概念:填充因子,它是MongoDB为每个新文档预留的增长空间。上边的这种情况就会使填充因子增加。
移动文档是一个非常缓慢的操作,尽量让填充因子的值接近1;
通过db.users.stats()查看该数据集信息,“paddingFactor”即为填充因子的大小;
三、删除
删除文档相对来说就简单了许多
1、单一删除
给定一个查询参数,只要符合条件的,都会被删除
db.users.remove({"_id":{"$lte":1}}) //删除“_id”的值小于等于1的所有文档
返回结果如下:
WriteResult({"nRemoved":2}) //成功删除了两个文档
2、清空整个数据集
db.users.remove()
如果数据较多的话,用db.users.drop()会明显提升删除速度
注:删除都是不可逆的,不能撤销,也不能恢复,所以要谨慎使用;
清空数据集的时候集合本身并不会被删除,也不会删除集合的元信息;
四、未解决问题
1、先取出来再更新,使用查询条件取出来的数据都无法用游标去获取值,但是用findOne获取的一个文档对象就可以。。。
如果哪位大神知道的话麻烦告诉小弟一下,多谢、、、哈哈。。
最后一个问题已经找到,原因如下:
第一个find操作虽然获取的只是一个文档对象,看似和下边用findOne是一样的效果,但是在MongoDB的shell中第一个的结果集是被默认为多个文档集合,所以它无法判断你想获取的是哪个文档的age。
三、MongoDB的创建、更新和删除的更多相关文章
- MongoDB数据库中更新与删除数据
MongoDB数据库中更新与删除数据 在MongoDB数据库中,可以使用Collection对象的update方法更新集合中的数据文档.使用方法如下所示: collection.update(sele ...
- MongoDB(二)创建更新删除文档
插入并保存文档操作 用insert向目标集合插入文档,如果没有_id键则会自动添加.最后自动保存. >db.foo.insert({"bar":"baz" ...
- MySQL----MySQL数据库入门----第三章 添加、更新与删除数据
3.1 添加数据 ①为所有字段添加数据 方法1:字段包含全部定义的字段 insert into 表名(字段1,字段2...字段n) values(值1,值2,......,值n); 方法2:值必须与字 ...
- [ABP教程]第三章 创建、更新和删除图书
Web应用程序开发教程 - 第三章: 创建,更新和删除图书 关于本教程 在本系列教程中, 你将构建一个名为 Acme.BookStore 的用于管理书籍及其作者列表的基于ABP的应用程序. 它是使用以 ...
- [转载]MongoDB学习 (四):创建、读取、更新、删除(CRUD)快速入门
本文介绍数据库的4个基本操作:创建.读取.更新和删除(CRUD). 接下来的数据库操作演示,我们使用MongoDB自带简洁但功能强大的JavaScript shell,MongoDB shell是一个 ...
- Mongodb 笔记02 创建、更新和删除文档
创建.更新和删除文档 1. 插入并保存: 1). 单条插入,insert : db.foo.insert({"bar":"baz"}) 2). ...
- MongoDB 的创建、查询、更新、删除
MongoDB数据库中,创建.查询.更新.删除操作的对象是集合. 1.查看某个数据库中有哪些集合,在此之前需要使用数据库 C:\Windows\system32>mongo MongoDB sh ...
- Mongodb基本数据类型、常用命令之增加、更新、删除
1.null---表示空值或者该字段不存在,如{"name":null} 2.布尔 --- 和java中的布尔一样,有两种:true,false,如{"sex" ...
- MongoDB的第二天(更新,删除,查询,索引)
Mongodb的更新方式有三种 update函数,操作符更新,save函数 update: 语法格式:db.COLLECTION_NAME.update({查询条件},{更新内容},{更新参数(可选) ...
随机推荐
- [SQL]SQL语言入门级教材_SQL功能与特性(一)
SQL功能与特性 其实,在前面的文章中,已经提及SQL命令的一些基本功能.然而,通过 SQL命令,程序设计师或数据库管理员(DBA)可以: (一)建立数据库的表格.(包括设置表格所可以使用之空间) ( ...
- HDU 4770 Lights Against Dudely
Lights Against Dudely Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Ot ...
- android 数据存储----文件方式 总结
在android中的文件放在不同位置,它们的读取方式也有一些不同. 本文对android中对资源文件的读取.数据区文件的读取.SD卡文件的读取及RandomAccessFile的方式和方法进行了整理. ...
- 初探接口测试框架--python系列1
点击标题下「蓝色微信名」可快速关注 坚持的是分享,搬运的是知识,图的是大家的进步,没有收费的培训,没有虚度的吹水,喜欢就关注.转发(免费帮助更多伙伴)等来交流,想了解的知识请留言,给你带来更多价值,是 ...
- "HTTP 错误 500.19 请求的页面的相关配置数据无效" 解决办法
HTTP 错误 500.19 - Internal Server Error无法访问请求的页面,因为该页的相关配置数据无效. 问题"详细错误信息模块 IIS Web Core通知 Begin ...
- 如何正确的使用Lerp In Unity
摘要 本文探讨如何用lerp实现近似的匀速旋转,当然如果运用本文给出的方法,使用slerp则可以实现匀速旋转,并指出Unity官方lerp示例代码的一些缺陷. 现有问题 比如四元数Lerp API: ...
- 【练习】手工生成awr报告
①首先进入$ORACLE_HOME/rdbms/admin目录 [oracle@host02 ~]$ cd $ORACLE_HOME/rdbms/admin 该目录下 [oracle@host02 a ...
- oracle限制用户连接数
查看是否启用限制配置 SQL> show parameter resource_limit; 或者 select * from v$parameterwhere name = 'resource ...
- 实用防火墙(Iptables)脚本分析
实用防火墙(Iptables)脚本分析 --Redhat,CentOS,Ubuntu等常见Linux发行版中都会预装Iptables防火墙,大多数初学者设置起来由于对这款软件比较陌生,设置起来比较困难 ...
- DedeCMS中function='Html2Text(@me)的用法分析
本文实例讲述了DedeCMS中function='Html2Text(@me)的用法.分享给大家供大家参考.具体分析如下: 在使用dedecms建站网站时候,需要用到过滤html代码,调出纯文本的代码 ...