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