MongoDB的基本概念
- MongoDB的数据单元是
文档
,可以看作JavaScript中的对象,类似于关系数据库中的行。 - 集合(Collection)类似于关系数据库中的表,区别在于没有模式。
- 每个MongoDB数据库都自身的集合和权限。
- MongoDB的操作主要靠终端的JavaScript Shell完成。
文档
在JavaScript中,文档表示为对象:
{"name": "XueSeason", "age": 22}
以上文档有一个name键,其值为XueSeason
,age键值为22
。
从这个文档,解释了几个概念:
- 文档中的键值对是有序的,上面例子中如果调换name和age的键值对,将会被视为一个新的文档。
- 文档中的值不仅仅只限于字符串形式,还有其他更高级的类型。
- 文档的键使用
UTF-8
字符。其中.
和$
通常被保留,只有在特定环境下使用,_
也是保留的。
集合
集合就是文档集,作为NoSQL是区别于关系数据库的表。
无模式
集合是无模式的。即不同类型的文档可以共存于同一个集合中:
{"name": "XueSeason", "age": 22}
{"book": "The old man and the Sea"}
注意上面的文档是完全不同的两个文档。既然一个集合可以容纳各种类型,为何需要多集合?
使用多集合的意义在于:
- 降低熵值。即减少混乱程度。
- 速度上的优越性。把一个特定类型的文档分成多个子集合提高查询效率。
- 把同种类型的文档存在一个集合汇总,使数据更集中。
推荐尽量使用子集合来组织数据。
命名
- 集合名不能为空字符串。
- 不能含有
\0
字符。 - 不能以
system.
开头,系统集合的保留前缀。 - 不能含有保留字符
$
。
启动MongoDB
确保你成功安装MongoDB并且正确配置。
终端输入mongod
命令。
如果出现类似以下信息:
2015-03-28T13:35:04.067+0800 W - [initandlisten] Detected unclean shutdown - /data/db/mongod.lock is not empty.
2015-03-28T13:35:04.067+0800 I STORAGE [initandlisten] exception in initAndListen: 98 Unable to lock file: /data/db/mongod.lock errno:35 Resource temporarily unavailable. Is a mongod instance already running?, terminating
2015-03-28T13:35:04.067+0800 I CONTROL [initandlisten] dbexit: rc: 100
表明已经有一个MongoDB程序在后台运行。
可以通过ps -ef
查找到相关的pid,执行kill [pid]
强制关闭。
MongoDB在没有参数的情况下默认会使用/data/db
目录,并监听27017端口。
如果该目录不存在或者不可写,服务器也会启动失败。
MongoDB Shell
运行mongo
启动shell:
xuejijiedeMacBook-Pro:~ xuejijie$ mongo
MongoDB shell version: 3.0.1
connecting to: test
>
此时,你可以用REPL方式执行JavaScript代码。
MongoDB客户端
MongoDB Shell的真正强大不仅在于是一个JavaScript的解释器,而且还是一个MongoDB客户端。
开启的时候,shell会连到MongoDB服务器的test数据库,并将这个数据库连接赋值给全局变量db
。
选择数据库:
> use mydatabase
switched to db mydatabase
> db
mydatabase
CRUD
接下来学习下操作数据的4个基本操作。
创建
使用insert
函数,可以添加文档到对应的集合中。
> post = { "title": "The first day", "content": "It is awesome time", "date": new Date()}
{
"title" : "The first day",
"content" : "It is awesome time",
"date" : ISODate("2015-03-28T05:53:16.355Z")
}
> db.blog.insert(post)
WriteResult({ "nInserted" : 1 })
> db.blog.find()
{ "_id" : ObjectId("551641e5b1f58081c3b9d7ea"), "title" : "The first day", "content" : "It is awesome time", "date" : ISODate("2015-03-28T05:53:16.355Z") }
上述操作首先创建一个post对象,然后通过insert方法将数据存放到blog集合中,最后通过find函数,展示blog集合中的所有文档。
此时文档多了额外的键_id
,是系统自动添加的主键。
读取
find会返回集合的所有文档。若只想查看一个文档,可以用findOne
。
关于更多查询内容,将作为新的文章讲解。
更新
update
函数接受两个参数:所更新文档的限定条件,新的文档。
> post.comment = []
[ ]
> db.blog.update({title: "The first day"}, post)
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.blog.find()
{ "_id" : ObjectId("551641e5b1f58081c3b9d7ea"), "title" : "The first day", "content" : "It is awesome time", "date" : ISODate("2015-03-28T05:53:16.355Z"), "comment" : [ ] }
删除
remove
函数永久删除文档,如果无参,就会删除集合内的所有文档。也可以接受限定条件删除指定内容。
更多shell指令可以通过help查看,或者参考官方doc。