1. 什么是MongoDB
MongoDB 是由C++语言编写的一个基于分布式文件存储的开源数据库系统。在高负载的情况下,添加更多的节点,可以保证服务器性能。
MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。
2. MongoDB 基本概念
SQL术语/概念 |
MongoDB 术语/概念 |
说明 |
database |
database |
数据库 |
table |
collection |
表/集合 |
row |
document |
数据行/文档 |
clumn |
field |
数据字段/域 |
index |
index |
索引/集合 |
table joins |
|
连接查询 (mongodb 不支持) |
primary key |
primary key |
主键(MongoDB 自动将_id作为主键) |
examples
id |
name |
addr |
0 |
zhao |
beijing |
1 |
li |
shanghai |
{
"_id" : ObjectId("xxx"),
"name": "zhao",
"addr": "beijing"
}
{
"_id" : ObjectId("xxx"),
"name": "li",
"addr": "shanghai"
}
3. MongoDB数据类型
类型 |
描述 |
样例 |
null |
null用于表示空值或者不存在的字段 |
{"x":null} |
布尔 |
布尔类型有两个值'true'和'false1' |
{"X":true} |
32位整数/64位整数/64位浮点数 |
javascript中只有一种数字类型,而MongoDB中有上面3中类型,默认情况下shell的数字都被MongoDB当作双精度。在shell下修改文档中的32位整形,也会被转换为64位浮点数。所以尽量不要在shell下面修改文档 |
{"X" : 3.1415926} {"X" : 3} |
字符串 |
UTF-8字符串都可表示为字符串类型的数据 |
{"x" : "foobar"} |
符号 |
不支持这种类型。shell将数据库里的符号类型转换成字符串。 |
对象id |
对象id是文档的12字节的唯一 ID |
{"X" :ObjectId() } |
日期 |
日期类型存储的是从标准纪元开始的毫秒数。不存储时区 |
{"X" : new Date()} |
正则表达式 |
文档中可以包含正则表达式,采用JavaScript的正则表达式语法 |
{"x" : /foobar/i} |
代码 |
文档中还可以包含JavaScript代码 |
{"x" : function() { /* …… */ }} |
二进制数据 |
二进制数据可以由任意字节的串组成。不过shell中无法使用。 |
|
最大值 |
BSON包括一个特殊类型,表示可能的最大值。shell中没有这个类型。 |
|
最小值 |
BSON包括一个特殊类型,表示可能的最小值。shell中没有这个类型。 |
|
未定义 |
文档中也可以使用未定义类型 |
{"x":undefined} |
数组 |
值的集合或者列表可以表示成数组 |
{"x" : ["a", "b", "c"]} |
内嵌文档 |
文档可以包含别的文档,也可以作为值嵌入到父文档中,数据可以组织得更自然些,不用非得存成扁平结构的 |
{"x" : {"food" : "noodle"}} |
网友评论