初识MongoDB
MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。
为什么选择MongoDB
网上搜索的结果说mongodb插入效率比mysql高云云的。。
不过主要应该是因为json的缘故,为什么json呢,因为围绕json有很多可用的开源产品,比如elasticsearch
不过依我看,最主要的原因就是其对JavaScript良好的支持吧
安装MongoDB
我们也可以利用homebrew和docker等第三方工具来进行MongoDB的安装
可视化工具
在这里我推荐Robomongo
没有原因,就是用着还挺顺手 -。-
启动MongoDB
打开终端,执行sudo mongod --config /usr/local/etc/mongod.conf
启动MongoDB,再另开一个终端输入mongo
就能成功打开mongo shell并进行咱们的操作了
界面如下
如果需要退出MongoDB,按下control+c
即可
注意:以上均在mac环境下成功实现,win 下本人还未尝试..下次找个机会试试
终于到了MongoDB操作时间
请开始我们的表演
插入数据
先利用use trevor-mongo
创建一个名为trevor-mongo的数据库
可以看到已经自动切换至trevor-mongo
这个数据库,现在就可以利用db.test.insertOne({title: "第一条数据"})
来插入一条数据
如果在数据库中没有数据表,MongoDB则会自动给你创建数据表
就这样,恭喜你,已经在test
数据表里面添加了第一条数据
查询数据
在上面我们已经添加了一条数据,那么现在可以在终端里面输入db.test.find({})
来查询test
数据表下的所有数据
大伙有没有觉得_id
很烦人??
其实我们完全可以将它过滤掉
在db.test.find({}, {_id: 0, title: 1})
这条命令里面,第一个大括号里面应该写入筛选条件,如果为空,则默认为all
。第二个大括号则是用来放数据显示条件,0代表不现实,1代表显示
修改(更新)数据
我们可以利用db.test.updateOne({},{$set: {des: "no.1"}})
来为数据添加一个des字段,再查寻一下
bingo!更新成功
删除数据
利用db.test.deleteOne({title: "第一条数据"})
,我们可以删除从开头起第一个title
为"第一条数据"
的文档
就这样,我们已经将最简单的操作给过了一遍,是不是很简单?所以说MongoDB对初学者真的很友好
进阶
在这之前,推荐先去看看MongoDB基本命令
现在,我们可以利用豆瓣开发者api来模拟一些数据
首先咱们先GET一下豆瓣电影top250的数据
将subjects
里面的数据复制并打开编辑器,输入
将这些代码粘贴至mongo shell
并执行,这样就在数据库下成功创建了一个名为movies
的数据表。
这时我们可以利用Robomongo来查看数据
首先是连接数据库,MongoDB默认端口号为27017
现在开始有目的性的查询数据
假设咱们有个需求,需要获得评分9.2以上的所有电影,并且只需显示电影名(title
),电影评分(rating.average
)以及电影年份(year
)并将它们升序排列输出
这说白了就是一个条件查询
代码如下:
db.movies.find({"rating.average": {$gt: 9.2}}, {title: 1, year: 1, "rating.average": 1, _id: 0}).sort({"rating.average": 1})
就这样成功完成查询,是不是很简单?
就这样,祝大家 have a nice day ; )
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。