mongoDB和sql数据库的区别

保持对代码的热爱并保持怀疑态度

mongodb和sql的区别

MongoDB 是一个基于分布式文件存储的数据库。

由 C++ 语言编写,是一个开源数据库系统。

旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。

MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。

MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。

MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。

在高负载的情况下,添加更多的节点,可以保证服务器性能。

关系型数据库(mysql)与非关系型数据库(mongodb)的区别:

在这里插入图片描述

了解两方的优缺点以及特性:

关系型数据库:

特性:

  • 关系型数据库是指采用了关系模型来组织数据的数据库
  • 关系型数据库的最大特点就是事务的一致性
  • 简单来说,关系模型指的就是二维表格模型,关系型数据库就是由二维表及其之间的关联组成的数据组织

特性:

  • 容易理解
  • 使用方便
  • 易于维护
  • 支持SQL,可用于复杂的查询

缺点:

  • 为了维护一执行需要消耗大量的性能,影响读写
  • 固定的表结构
  • 高并发读写需求
  • 海量数据的高效率读写

非关系型数据库:

特性:

  • 使用键值对存储数据
  • 分布式
  • 不支持ACID特性
  • 非关系型数据库严格上来说,不算是一种数据库,应该是一种数据结构化存储方法的集合

优点:

  • 无需经过sql层的解析,读写性能高;
  • 基于键值对,数据没有耦合性,容易扩展;
  • 存储数据的格式,nosql使用key:val的形式,文档的形式,图片形式等等,而关系型数据库则只支持基础类型

缺点:

  • 不提供sql支持,学习成本高
  • 无事务处理,附加功能和报表支持也不好
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
MongoDBSQL是两种不同类型的数据库管理系统,它们在数据存储和查询方面有一些区别。 1. 数据模型:MongoDB是一种文档数据库,它使用类似JSON的BSON(二进制JSON)格式来存储数据。每个文档可以具有不同的结构,这使得MongoDB非常灵活。而SQL是基于表的关系数据库,数据以表格形式存储,每个表都有固定的列和行。 2. 查询语言:MongoDB使用一种称为MongoDB查询语言(MQL)的语言来进行查询,它与JavaScript语法相似。MQL支持丰富的查询操作符和聚合功能。SQL使用结构化查询语言(SQL)进行查询,它是一种通用的查询语言,用于处理关系型数据。 3. 扩展性:MongoDB具有良好的横向扩展性,可以轻松地在多个服务器之间分布数据。而SQL数据库通常以垂直方式扩展,通过在单个服务器上增加硬件资源来提高性能。 4. 事务支持:SQL数据库通常支持事务处理,可以保证数据的一致性和完整性。而MongoDB在早期版本中缺乏对事务的完全支持,但在最近的版本中已经添加了对多文档事务的支持。 5. 数据关系:SQL数据库使用外键来建立数据之间的关系,这使得在查询和连接多个表时更加方便。MongoDB没有内置的外键概念,但可以通过嵌入文档或手动引用文档来建立关系。 总的来说,MongoDB适用于需要灵活数据模型和大规模横向扩展的场景,而SQL数据库适用于需要严格结构化数据和事务支持的场景。选择哪种数据库取决于具体的业务需求和数据特点。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

划水的乌贼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值