1 MongoDB简介
mongodb是开源的文档数据库,提供了高性能,高可用性和自动伸缩的数据库服务。mongodb不需要使用ORM工具来简化开发。
1.1 文档(document)
mongodb的每条记录就是一个文档,文档实际上是一个数据结构,包括属性域(field)和对应的值(value)。mongodb的文档类似JSON对象,每个属性域的值可以是另外一个文档,后者数组,或者包含一系列文档的数组。
document示例:
{
"_id" : ObjectId("54c955492b7c8eb21818bd09"),
"address" : {
"street" : "2 Avenue",
"zipcode" : "10075",
"building" : "1480",
"coord" : [ -73.9557413, 40.7720266 ]
},
"borough" : "Manhattan",
"cuisine" : "Italian",
"grades" : [
{
"date" : ISODate("2014-10-01T00:00:00Z"),
"grade" : "A",
"score" : 11
},
{
"date" : ISODate("2014-01-16T00:00:00Z"),
"grade" : "B",
"score" : 17
}
],
"name" : "Vella",
"restaurant_id" : "41704620"
}
1.2 集合(collection)
mongodb将文档(document)存储在集合(collection)中,集合类似于关系型数据库中的表(table)。与表不同的是,集合不要求它的文档拥有相同的。
mongodb中,在集合中的每个文档必须有一个_id属性(唯一性),与关系型数据库表的主键(primary key)类似。
2 MongoDB Shell
mongo shell是MongoDB的Javascript交互界面。可以通过mongo shell来查询,更新数据以及进行数据库管理操作。
mongo shell是MongoDB的一个组件,安装并启动MongoDB后,就可以连接mongo shell管理MongoDB数据库。
2.1 启动mongo shell
在启动mongo shell之前,请先启动MongoDB数据库
启动mongo shell,连接在localhost上默认端口的MongoDB数据库
cd <mongodb installation dir>
.bin/mongo
如果已经将<mongodb installation dir>/bin
添加到PATH环境变量中,那么直接输入mongo即可启动mongo shell
mongo
命令在不适用任何参数的情况下,将会连接ip为localhost,端口为27017上的MongoDB数据库。可查看参数选项对ip和端口进行配置。
.mongorc.js
mongo
启动时将会检查HOME($HOME)目录下是否有.mongorc.js文件。如果找到,那么在进入交互界面之前将会首先解析.mongorc.js文件中的内容。当使用mongodb执行Javascript文件,JS表达式,在命令行使用--eval选项或者指定一个.js文件,mongo都会在执行完Javascript后读取.mongorc.js中的内容。可使用--norc
选项阻止.mongorc.js文件的载入
2.2 使用mongo shell
- 帮助
help
- 显示使用的数据库
db
- 切换数据库
use <database>
列出所有数据库
show dbs
可以直接切换到一个不存在的数据库,当第一个向该数据库存储数据时,MongoDB会创建这个数据库。下面的示例将创建myNewDatabase数据库,并且创建myCollection集合
use myNewDatabase
db.myCollection.insert({x:1});
如果集合名称包含空格,-字符,或者以数字开头,那么可以使用db['collection']方式访问集合,例如
db["3test"].find()
db.getCollection("3test").find()
mongo shell每行只能接收4095个code point(一个Unicode字符时一个code point),如果超出将会截断
2.3 格式化输入结果
db.collection.find()
方法将会返回一个结果的游标(cursor),如果返回的游标未被使用var进行读取,那么游标将会自动迭代20次,读取符合查询条件的前20个文档。如果未读取完毕,mongo shell将会提示 Type "it" for more
可使用.pretty()
方法对结果进行格式化,例如
db.myCollection.find().pretty()
此外,mongo shell还支持以下打印方法
-
print
打印(不进行任何格式化) -
print(tojson(<obj>))
打印JSON格式,与printjson()相同 -
printjson()
打印JSON格式,与`print(tojson(<obj>))相同
多行输入
如果以[或者{或者(作为行的结尾,那么mongo shell将会在下一行自动添加...,等待对应的】或者}或者)
如果连续两行...未输入任何内容,那么将会退出等待
2.4 tab自动完成和其他快捷键
mongo shell支持快捷键,例如
- up和down箭头键,可以遍历输入过的命令
- tab可以自动补全命令
2.5 退出shell
输入quit()
或者使用ctrl+c