专栏首页技术面面观三分钟 mongodb 开发快速上手

三分钟 mongodb 开发快速上手

三分钟 mongodb 开发快速上手

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

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

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

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

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

这是一篇科普文。

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

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

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

像这张图,各种类型的字段都存在里面。看上去和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 对象。

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

点击放大查看图片

集合(collection)?

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

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

查看当然库有哪些集合

> show collections
coding3min

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

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

本文分享自微信公众号 - 编程三分钟(coding3min),作者:机智的小熊

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2020-04-22

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Git 版本控制,看这篇就够了 (一)

    git是世界上目前最先进的分布式版本控制系统,致力于团队、个人进行项目版本管理,完美的解决难以比较代码、难以合并代码、难以取消修改、难以在写当前代码的过程中保存...

    机智的程序员小熊
  • 到底是哪条SQL拖慢了你的数据库?

    开启慢查询日志,可以让MySQL记录下查询超过指定时间的语句,通过定位分析性能的瓶颈,才能更好的优化数据库系统的性能。

    机智的程序员小熊
  • 如何保留原提交记录迁移Git项目,你还不知道吗?

    为了让项目能实现Git+Gerrit+Jenkin的持续集成,我们把项目从Git上迁移到了Gerrit上,发现有的同事在老Git提交代码,因为Gerrit做了同...

    机智的程序员小熊
  • Python在SQLite数据库中动态创建数据表的思路与实现

    在管理信息系统或者动态网站开发时,离不开数据库的使用。以SQLite数据库为例,系统运行时要求数据库和对应的数据表已存在,一种方案是提前建好数据库和所有表,再一...

    Python小屋屋主
  • Skype for Business Server 2015 后端数据库配置镜像见证(mirroring witness)

    早期部署Skype for Business Server 2015后端数据库采用2台并使用镜像,未配置见证数据库,当遇到主数据库宕机时,需要手动迁移数据库,现...

    杨强生
  • 不知道CynosDB为什么叫真正的云原生数据库?腾讯云数据库的产品欧巴今天跟你聊一聊

    注:本文摘自2018年11月22日腾讯云数据库CynosDB新品发布会的演讲实录。随着互联网信息的发展,大家也对云这个词汇也不是特别陌生了,作为全球首选的云服务...

    腾讯云数据库 TencentDB
  • Gartner最新报告:腾讯云数据库增速国内第一

    近日,国际权威研究机构Gartner公司发布《The Future of the Database Management System (DBMS) Marke...

    勤劳的小蜜蜂
  • MySQL不香吗,为什么还要有noSQL?

    其实我很早就想写写分布式数据库相关的文章,既是我现在正在学习的,也是我很感兴趣的内容。但是谈到分布式数据库,会涉及很多相关的技术细节,等把相关的一些细节写明白的...

    TechFlow-承志
  • 分布式文件存储的数据库开源项目MongoDB

    MongoDB是一个基于分布式文件存储的数据库开源项目。由C++语言编写。旨在为WEB应用提供可护展的高性能数据存储解决方案。 它的特点是高性能、易部署、易使用...

    张善友
  • 分布式文件存储的数据库——Mongodb

    什么是mongodb MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。    MongoD...

    cloudskyme

扫码关注云+社区

领取腾讯云代金券