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中的操作时瞬时完成的,这是因为它们都不需要等待数据库的响应,这并不是异步操作,客户端将文档发送给服务器后就立刻干别的了。
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。