MongoDB学习笔记01

MongoDB的设计理念:能从服务器端转移到驱动程序来做的事,就尽量转移。

文档是MongoDB的核心概念。多个键及其关联的值有序的放置在一起便是文档。每种编程语言表示文档的方法不太一样。

文档的键是字符串。除了少数例外情况。键可以使用任意UTF-8字符。键不能含有\0(空字符),这个字符用来表示键的结尾;.与$有特别的意义,只有在特定环境下才能使用;以下划线“_”开头的键是保留的,虽然这个并不是严格要求的。

MongoDB区分类型与大小写。{“foo”:"3"}与{"foo":3}  {"foo":3}与{"Foo":3},它们是不同的。

MongoDB不能有重复的键。

集合就是一组文档。如果说MongoDB中的文档类似于关系数据库中的行,那么集合就如同表,多个集合可以组成数据库。集合是无模式的,这意味着一个集合里面的文档可以是各种各样的。我们可以通过名字来标识集合,集合名可以是任意UFT-8字符串,只要满足一下条件:

1. 集合名不能是空字符串

2. 集合名不能含有\0字符,这个字符表示集合名的结尾

3. 集合名不能以"system."开头,这是为系统集合保留的前缀。

4. 用户创建的集合名字不能含有保留字符$。有些驱动程序的确支持在集合名里面包含$,这是因为某些系统生成的       集合中包含该字符。除非你要访问这种创建的集合,否则千万不要在名字里出现$

多个集合可以组成数据库,和集合一样数据库也通过名字来标识,数据库的名可以是满足一下条件的任意UFT-8字符串:

  1. 不能是空字符串

  2. 不能含有‘‘(空格)、.、$、/、\和\0(空字符)

  3. 应全部小写

  5. 最多64字节

数据库名最终会变成文件系统里的文件,这也是如此多限制的原因。把数据库的名字放到集合前面,得到就是集合的完全限定名,称为命名空间。命名空间的长度不得超过121字节,在实际使用当中应小于100字节。 

MongoDB默认使用27017端口.

启动MongoDB并指定数据保存的位置 bin\mongod.exe  --dbpath 数据存储的路径,默认保存在(c:\data\db)   

插入数据

技术分享

 读取数据

技术分享

  find会返回集合里面所有的文档,若只想查看一个文档,可以使用findOne。find与findOne可以接受查询文档形式的限定条件。使用find时,shell自动显示最多20个匹配的文档,但可以获取更多文档。  

更新数据技术分享 删除数据

技术分享

mongo是MongoDB的shell客户端,是一个内置的JavaScript解释器,它还有一些非JavaScript语法的扩展。

有个了解函数功能的技巧,就是在输入的时候不要输入括号,这样会显示该函数的JavaScript源代码,如想看find的机理或参数:

技术分享

JavaScript只有在db中找不到指定的属性时,才会将其作为集合返回,当属性与目标集合同名时,可以使用getCollection函数,要查看名称中含有无效JavaScript字符的集合,这个函数也可以派上用场。

ObjectId使用12字节的存储空间,每个字节两位十六进制数字,是一个24位的字符串。这个长长的ObjectId是实际存储数据的两倍长。ObjectId的构成如下:

技术分享

时间戳精确到秒级别

修改器:$set 如果指定的键不存在则创建它

           $unset 删除指定的键

     $inc 增加已有键的值,或键不存在时创建一个键,只能作用于整数、长整数或双精度浮点数

     $ne与$addToSet 数组中有重复的数据时不会添加

          $push 如果指定的键已经存在,会向已有的数组末尾加入一个元素,要是没有就会创建一个新的数组

          $each

          $pull 会将所有匹配的部分删掉

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

          数组的定位修改:通过位置(从0开始)或定位操作符("$")【定位符只更新第一个匹配的元素】

upsert是一个特殊的更新,要没有文档符合更新条件,就会以这个条件和更新文档为基础创建一个新文档,如果找到了匹配的文档,则正常更新。效果如图:技术分享

save是一个shell函数,可以在文档不存在时插入,存在时更新,他只有一个参数:文档。要是这个文档含有"_id"键,save会调用upsert,否则会调用插入。

技术分享

想要知道更新了多少个文档,可以运行getLastError命令

技术分享

findAndModify命令中每个键对应的值如下:

  findAndMondify:集合名

  query:查询文档,用来检索文档的条件

  sort: 排序结果的条件

  update:修改文档,对找到的文档执行更新

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

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

“update”与“remove”必须有一个也只能有一个,要是匹配不到文档,这个命令会返回一个错误。相比普通的更新来说,findAndMondify速度要慢一些。

技术分享

MongoDB中的操作时瞬时完成的,这是因为它们都不需要等待数据库的响应,这并不是异步操作,客户端将文档发送给服务器后就立刻干别的了。

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。