mangodb可以有多个instance,一个instance可以有多个database,
database又可以有多个collection,每个collection也可以有多个document
1、文档(Document)
mongoDB的基本单位,相当于关系数据库中的行。它是一组有序的key/value键值对,
使用json格式,如:{
"foo"
: 3,
"greeting"
:
"Hello, world!"
}。
(1)key是个UTF-8字符串,以下几点是需要注意的地方:
- 不能包含\0字符(null字符),它用于标识key的结束
- .和$字符在mangodb中有特殊含义,如$被用于修饰符($inc表示更新修饰符),应该考虑保留,以免被驱动解析
- 以_开始的key也应该保留,比如_id是mangodb中的关键字
(2)value 是弱类型,甚至可以嵌入的一个document
(3)key/value键值对在mangodb中是有序的
(4)mangodb是类型和大小写敏感的,如{"foo" : 3}和{"foo" : "3"}是两个不同的document,{"foo" : 3}和{"Foo" : 3}类似
2、集合(Collection)
因为是无结构定义的,所以你可以把任何document存入一个collection里。每个
collection用一个名字标识,需要注意以下几点:
- 名字不允许是空字符串""
- 名字不能包含\0字符,因为它表示名字的结束
- 不能创建以system.开头的
3、数据库(Database)
一个mongoDB的实例可以运行多个database,database之间是完全独立的,每个database有自己的权限,每个database存储于磁盘的不同文件。
同collections的name一样,databases的name可以是任意的UTF-8字符串。但是有以下限制:
- 空字符串””是非法的
- 不允许出现’’,.,$,/,\,\0字符
- 建议名称都是小写
- 不能超过64个字节
有几个保留的名字不能用在databases的name中:
- admin:它是root级别的数据库,如果一个用户创建了admin数据库,该用户将自动集成所有数据库的权限,它可以执行一些服务器级别的命令,如列出所有数据库、关闭服务等。
- local:该数据库将永远不能被复制,只能在单台服务器本地使用。
- config:存储分布式部署时shard的配置信息
4、数据类型
- null
- boolean
- 32位整数
- 64位整数(同上)
- 64位浮点小数
- string
- symbol
- object id
Timestamp|Machine | PID |Increment
如{"x" : ObjectId()}
- date
- 正则表达式
如何javascript语法的正则表达式
如{"x" : /foobar/i}
- code
javascript的代码
如{"x" : function() { /* ... */ }}
- 二进制数据
- maximum value
bson有这样一个专门的类型来表示可能的最大值,shell不支持此类型。 - minimum value
- undefined
- array
- embeded document