暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Mysql和mongoDB的区别(IT枫斗者)

IT枫斗者 2023-04-03
281
hello大家好,最近有好多同学问到mongodb,今天跟大家说说mongodb和mysql这两者的区别。

什么是MongoDB呢 ?
MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。
在高负载的情况下,添加更多的节点,可以保证服务器性能。
MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案。
MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。

它的主要特点有哪些?

MySQL与MongoDB都是开源的常用数据库,但是MySQL是传统的关系型数据库,MongoDB则是非关系型数据库(另称文档型数据是一种NoSQL的数据库。它们各有各的优点,关键是看用在什么地方。所以我们所熟知的那些SQL语句就不适用于MongoDB了,因为SQL语句是关系型数据库的标准语言。

一、关系型数据库-MySQL

  1. 在不同的引擎上有不同的存储方式。
  2. 查询语句是使用传统的sql语句,拥有较为成熟的体系,成熟度很高。
  3. 开源数据库的份额在不断增加,mysql的份额页在持续增长。
  4. 缺点就是在海量数据处理的时候效率会显著变慢。

二、非关系型数据库-MongoDB
非关系型数据库(nosql ),属于文档型数据库。先解释一下文档的数据库,即可以存放xml、json、bson类型系那个的数据。这些数据具备自述性,呈现分层的树状数据结构。数据结构由键值(key=>value)对组成。
  1. 存储方式:虚拟内存+持久化。

  2. 查询语句:是独特的MongoDB的查询方式。
  3. 适合场景:事件的记录,内容管理或者博客平台等等。

  4. 架构特点:可以通过副本集,以及分片来实现高可用。

  5. 数据处理:数据是存储在硬盘上的,只不过需要经常读取的数据会被加载到内存中,将数据存储在物理内存中,从而达到高速读写。

  6. 成熟度与广泛度:新兴数据库,成熟度较低,Nosql数据库中最为接近关系型数据库,比较完善的DB之一,适用人群不断在增长。

三、MongoDB优势与劣势

优势:
  • 在适量级的内存的MongoDB的性能是非常迅速的,它将热数据存储在物理内存中,使得热数据的读写变得十分快。

  • MongoDB的高可用和集群架构拥有十分高的扩展性。

  • 在副本集中,当主库遇到问题,无法继续提供服务的时候,副本集将选举一个新的主库继续提供服务。

  • MongoDB的Bson和JSon格式的数据十分适合文档格式的存储与查询。

劣势:
  • 不支持事务操作。MongoDB本身没有自带事务机制,若需要在MongoDB中实现事务机制,需通过一个额外的表,从逻辑上自行实现事务。
  • 应用经验少,由于NoSQL兴起时间短,应用经验相比关系型数据库较少。
  • MongoDB占用空间过大。
    下面是Mysql和mongoDB的对比:
最近在更新过关斩将系列——java面试题,全力帮助小白突破面试大关,目前已经更新至第29篇感兴趣可以关注公众号IT枫斗者追更

往期回顾



侃一侃Redis如何实现消息列队

过关斩将之路-RocketMQ基础知识(中)

浅谈Redis缓存刷新策略

过关斩将之路-RocketMQ基础知识(上)

Mysql读写分离的方案

过关斩将之路-Rocket MQ基础知识(下)

有关java面试题系列专题,已分享整理在公众号首页—面试宝典系列,还有真实企业面试,经典offer成功案例等。

👉 如果本文对你有帮助的话,欢迎 点赞&在看&分享 ,这对我继续分享&创作优质文章非常重要。非常感谢!

文章转载自IT枫斗者,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论