小熊昨天晚上做了一个非常真实的噩梦,有读者朋友催我”怎么又没有发文!让我们等的好辛苦“,今天一睁开眼眼看后台留言,特么,居然是真的!

三分钟 mongodb 开发快速上手_nosql

我​​bilibili​​直播申请都通过了!但是别想让我吃粑粑!

三分钟 mongodb 开发快速上手_mongodb_02

这两天我虽然没有更新文章,主要因为小熊最近的工作密度比较大,有时候为了能够​​偷懒​​花一些时间主动写一些脚本或者代码,减少很多人力的操作,这种事情没有人要求小熊,但是我还是会主动去,长痛不如短痛就是这个道理。

工作之余我可没有闲着,今天要和大家分享的是来自一位读者的要求,他们小组马上要用​​mongodb​​了,但是以前从来没有接触过,小熊就满足你的需求。

三分钟 mongodb 开发快速上手_数据库_03

有道是,无巧不成书,我们也用到了​​mongdb​​​,不过对于小熊个人来说,对​​mongodb​​的接触仅限于维护的时候看看表结构,更新几行记录什么的,正好逮到这个契机下决心好好总结一下。

这是一篇科普文。

为什么用(有在哪,有什么好处) ?

我们用 ​​mongodb​​ 比较感兴趣的是为什么要用他?他有什么好处?什么时候该用?具体怎么用?

三分钟 mongodb 开发快速上手_mysql_04

​mongo​​​ 相对于传动的关系型数据库,例如​​MySQL​​来说,他对每一次插入的字段格式没有要求,字段可以随意变动。

三分钟 mongodb 开发快速上手_数据库_05

像这张图,各种类型的字段都存在里面。看上去和​​Mysql​​​长的很像,但是他是去​​sql​​​的一种数据库。就是我们常说的​​nosql​

​MongoDB​​ 的优点/缺点

​MongoDB​​ 的优势主要有 3 个。

  • 结构灵活,表结构更改比较自由,不用因为增减字段每次 ​​alter​​ 的时候付出代价,适合业务快速迭代,而且 ​​json​​ 原生和大多数的语言有天然的契合。还支持数组,嵌套文档等数据类型
  • 自带高可用,自动主从切换(副本集)
  • 自带水平分片(分片),内置了路由,配置管理。应用只要连接路由,对应用来说是透明的。

也具备所有​​NoSQL​​的其他优点。

  • 他可以并发插入上万条文档
  • 高可扩展性,在负载高的情况下,只需要添加更多的节点,就可以保证服务器的性能。
  • 分布式计算
  • 低成本,轻量化部署非常简单
  • 没有复杂的关系

缺点:

  • 没有标准化
  • 程序不直观

主要记得灵活、好用、速度快、容器扩展运维方便就好了,不像​​MySQL​​那样,对集群同步要求那么高。

基本概念

​mongodb​​ 中基本的概念是文档、集合、数据库,让我由外而内和大家聊聊。

和​​MySQL​​对比来看就是

  • 数据库——>数据库
  • 表————>集合
  • 行————>文档
  • 列 ————>字段

数据库(db)?

和​​MySQL​​​一样,一个 ​​mongodb​​ 中可以建立多个数据库。

展示所有的数据库

> show dbs
local 0.078GB
test 0.078GB

运行​​use​​命令,可以连接到一个指定的数据库(没有则创建)。

> use coding3min
switched to db coding3min

执行 ​​db​​ 命令可以显示当前数据库对象或集合。

> db
coding3min

文档(Document)?

说集合之前,要先说说集合里所有的行记录,也就是文档,类似​​MySQL​​表中一行一行的记录。

文档是个什么东西呢?他长的就像 ​​JSON​​ 对象。

三分钟 mongodb 开发快速上手_nosql_06

数据结构由键值 ​​(key=>value)​​​ 对组成。字段值可以包含其他文档,数组及文档数组,简直和​​json​​一毛一样。

三分钟 mongodb 开发快速上手_mysql_07

集合(collection)?

集合类似​​MySQL​​中的表,就是文档的集合。

db.createCollection("coding3min", {happy:true, age:18})

查看当然库有哪些集合

> show collections
coding3min

其实你不用刻意创建集合。在插入文档的时候,会自动创建。

这就是​​Mongo​​的简单入门啦,我们先讲应用,以后有机会再聊聊业务怎么设计,怎么真正的用起来,系统的讲讲有哪些比较重要的点。下次再见啦。