MySQL和MongoDB那些事

2023-11-12

什么是 MySQL 和 MongoDB

MySQL 和 MongoDB 是两个可用于存储和管理数据的数据库管理系统。MySQL 是一个关系数据库系统,以结构化表格格式存储数据。相比之下,MongoDB 以更灵活的格式将数据存储为 JSON 文档。两者都提供性能和可扩展性,但它们为不同的应用场景提供了更好的性能。

MySQL 是一种关系型数据库管理系统,它使用结构化查询语言(SQL)来操作数据。SQL 是一种通用的、标准化的、声明式的语言,它可以定义数据的结构、约束、操作、查询等。MySQL 使用表(table)来存储数据,表由行(row)和列(column)组成,每一行代表一条记录,每一列代表一个属性。表之间可以通过主键(primary key)和外键(foreign key)来建立关联,实现数据的完整性和一致性。

MongoDB是一种非关系型数据库管理系统,它使用文档(document)来存储数据。文档是一种类似于 JSON 的格式,它由键值对(key-value pair)组成,每一个键值对代表一个属性。文档之间没有固定的结构,可以根据需要灵活地添加或删除属性。文档存储在集合(collection)中,集合类似于表,但没有预定义的模式(schema)。集合之间可以通过引用(reference)或嵌入(embedding)来建立关联,实现数据的灵活性和效率。

相似之处

MySQL 和 MongoDB 都是数据库管理系统。它们存储数据并具有内置的用户界面和查询语言,因此我们都可以进行添加、编辑、修改和分析数据等操作。

开源许可证

MySQL 和早期版本的 MongoDB 都有开源许可证,可以免费下载开源版本。我们可以根据需要对代码执行的操作来对其进行修改。MySQL 使用 GPL 协议,使得任何人均可以免费使用 MySQL 并且可以对其进行代码修改。而 MonogoDB 在 2018 年 10 月 16 日更改 License 为 SSPL 协议,这对于开源社区没啥影响,但是对于云厂商而言 MongoDB 公司会明确要求托管 MongoDB 实例的云厂商要么从 MongoDB 公司获取商业许可证,要么向社区开源其服务代码。

索引支持

MySQL 和 MongoDB 使用索引来提高查询速度和性能。索引是加快数据查询的一种数据库结构,有助于非常快速地查找和检索数据。MySQL 和 MongoDB 数据库平台都使用哈希索引、B- 树(MySql实际使用的是B+ 树)索引和其他几种索引。

用户界面

MongoDB 和 MySQL 都易于使用。它们提供基于自然语言的查询语言来更新和读取数据,还提供图形用户界面(GUI),以便更直观地管理和分析数据。

编程语言

MySQL 和 MongoDB 与各种相同的编程语言兼容。MongoDB 和 MySQL 都可以与 Java、Python、Node.js、PHP、Ruby 以及 C# 结合使用。

安全性

MySQL 和 MongoDB 都使用身份验证、访问控制和加密手段来确保其数据库的安全。它们使用 TLS/SSL 加密来保护传输中数据和静态数据,还允许定义不同的用户访问级别。

文档和社区支持

MySQL 和 MongoDB 在各自的网站上都有详细的官方文档。两者的教程、手册和指南包含安装、配置和运行操作任务的完整说明。MongoDB 和 MySQL 都有一个活跃的开发人员社区,可以回答问题并帮助进行故障排除。它们还提供企业版,针对特定要求提供专属支持。

主要区别

MySQL 是一个关系数据库管理系统,MongoDB 则是一个 NoSQL 数据库系统。MySQL 使用 SQL,大多数开发人员都有这方面的经验。相反 MongoDB 使用 MongoDB 查询语言(MQL)。尽管 MQL 和 SQL 有相似之处,但 MQL 通常需要额外花费精力进行学习。 接下来,博主将介绍一些主要差异。

数据模型

MySQL 是一个关系数据库系统,它将数据存储在列、行和表中。我们将数据存储在行中,每列代表不同类型的数据。然后我们就可以使用外键和主键定义数据之间的关系。每个表都有一个用于标识它的主键,外键用于创建关系。

MongoDB 是一个面向文档的数据库,将其所有数据存储为二进制 JSON(BSON)文档。BSON 允许序列化多种形式的数据。使用 BSON 文档可以存储非结构化、半结构化和结构化数据。MongoDB 没有使用数据库架构,而是采用了一种灵活的方法,将文档存储在集合中。

可扩展性

在 MySQL 数据库系统中,可用的扩展选项是有限的。有以下方案可供选择:

  • 通过向当前数据库服务器添加更多资源来实现纵向可扩展性
  • 通过在其他服务器上创建数据库的只读副本来读取复制

创建制度副本有限制,最多只能有五个副本。副本还可能滞后于主副本,会造成一致性问题。纵向可扩展性也受限于单机性能瓶颈。

相比之下,MongoDB 在可扩展性方面具有显著的优势。它具有两个用于扩展的关键功能:

  • 副本集 — 包含相同数据的 MongoDB 服务器备份
  • 分片 — 将数据分布在不同的服务器上

MongoDB 允许创建分片集群,因此我们的部分数据将在多个服务器上复制。例如如果我们有大量的客户记录,则可以对其进行分发,以便将 A-J 的姓名和 K-Z 的姓名保存在各自的副本集中。因此 MongoDB 可以横向扩展,以大规模优化读写性能。

性能

MySQL 设计为可在建立适当索引的多个表之间实现高性能连接。但是它需要逐行插入数据,因此写入性能较慢。

MongoDB 文档遵循分层数据模型,将大部分数据保存在单个文档中,从而减少了跨多个文档进行联接的需要。通过 $lookup 操作支持联接,但并未针对性能对其进行优化。但是 MongoDB 提供了 insertMany() API,用于快速插入数据,可优先考虑写入性能。

灵活性

作为关系数据库管理系统,MySQL 的结构比 MongoDB 更严格。MySQL 使用固定架构,将数据整理成行和表。必须将数据结构化并放入表格系统中才能使用 MySQL。

通过将数据存储为 JSON 文档,MongoDB 允许构建具有许多不同数据类型的复杂应用程序。例如可以通过更新嵌套数组字段来创建新字段。还可以使用聚合管道(这是一个 MongoDB 功能),允许通过将多个操作合并为一个工作流程来转换数据。

访问控制

在 MongoDB 中,可以控制操作、集合或数据库级别的访问权限。它使用 Kerberos、X.509 和 LDAP 证书对用户进行身份验证。相比之下,MySQL 允许在用户、数据库和表级别上限制用户访问权限。MySQL 使用自己的身份验证系统。它会在 SQL 注入攻击中带来另一个安全漏洞,MongoDB 的无架构方法则可以避免这个漏洞。

差异表格

MongoDB MySql 数据模型 MongoDB 将数据存储在 JSON 文档中,然后将其整理成集合。 MySQL 将数据存储在列和行中。数据存储是表格式和关系式的。 可扩展性 MongoDB 使用复制和分片进行水平扩展。 MySQL 使用纵向扩展和只读副本来大规模提高性能。 查询语言 MongoDB 使用 MongoDB 查询语言。 MySQL 使用 SQL。 性能 MongoDB 擅长插入或更新大量记录。 查询大量记录时,MySQL 的速度更快。 灵活性 MongoDB 没有架构,因此具有更大的灵活性,并且能够处理非结构化、半结构化和结构化数据。 MySQL 有严格的架构,可以很好地处理结构化数据。 安全性 MongoDB 使用 Kerberos、X.509 和 LDAP 证书对用户进行身份验证。 MySQL 使用内置的身份验证方法。

优缺点

MySQL 和 MongoDB 各有优缺点,如下展示:

  • MySQL 的优点: 成熟稳定:MySQL 是一个历史悠久、广泛使用、经过测试的数据库系统,有着丰富的文档和社区支持。易用强大:MySQL 提供了一个简单易用、功能强大的 SQL 语言,可以实现复杂的查询和操作。数据安全:MySQL 支持 ACID 事务,可以保证数据的完整性和一致性,避免数据丢失或错误。
  • MySQL 的缺点: 灵活性低:MySQL 需要预先定义好数据的结构和类型,不适合存储动态变化或非结构化的数据。扩展性差:MySQL 只支持垂直扩展,不适合处理海量或分布式的数据。性能瓶颈:MySQL 在处理大量的连接、并发、索引、关联等操作时,可能会出现性能瓶颈或故障。
  • MongoDB 的优点: 灵活性高:MongoDB 使用文档模型,可以动态地调整数据的结构和类型,适合存储动态变化或非结构化的数据。扩展性好:MongoDB 支持水平扩展,可以处理海量或分布式的数据,提高系统的可用性和容错性。性能高效:MongoDB 在处理大量的读写、索引、嵌入等操作时,可以实现高效的性能和吞吐量。
  • MongoDB 的缺点: 难用复杂:MongoDB 提供了一个难用复杂、功能有限的 MQL 语言,不能实现复杂的查询和操作。数据不安全:MongoDB 不支持 ACID 事务,不能保证数据的完整性和一致性,可能导致数据丢失或错误。

应用场景

MySQL 和 MongoDB 适合不同的应用场景,以下是一些主要的例子:

MySQL 适合以下场景:

  • MySQL 中的数据存储格式使其适用于数据仓库和在线分析处理。它符合 ACID 标准,这使得 MySQL 适用于处理复杂事务,例如在电子商务、交易应用场景中。
  • 需要确保数据安全、一致性、可靠性等特性的场景,例如政府、金融等领域。

MongoDB 适合以下场景:

  • MongoDB 在社交网络、媒体或物联网(IoT)等应用场景中处理非结构化数据时,该数据库更为合适。
  • 需要进行大量的读写、索引、嵌入等操作的场景,并且需要数据可扩展可变化,例如内容管理、个性化推荐等领域。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

MySQL和MongoDB那些事 的相关文章

  • MongoDB自增ID

    MongodB 中自动生成的 ID 的大小为12 Bytes大整数的大小是8 bytes 我在 4 台运行 Ubuntu Server 的机器上有一个 mongodb 集群 但我现在只是在测试 插入只能通过一台服务器 即 Nodejs 服务
  • Mysql innoDB 不断崩溃[关闭]

    Closed 这个问题不符合堆栈溢出指南 help closed questions 目前不接受答案 我的数据库 mysql 服务器不断崩溃 重新启动 我不知道该怎么办 我不断在 dbname org err 文件中收到以下内容 13120
  • 为什么 MySQL 创建带有 _seq 后缀的表?

    我创建了一个 InnoDB 表 名为foo在 MySQL 中 一旦我对表执行插入操作 我就会看到另一个表foo seq被建造 如果我删除自动生成的表 它会在下一次插入后出现 是什么原因造成的 听起来像是正在创建一个序列 您是否有自动生成的主
  • Mongodump之后,调用MongoRestore挂起

    我们正在尝试在相对较小的数据库上做一个简单的 MongoDump 我们的步骤很简单 export 从目标机器上删除现有数据库 在目标机器上导入 MongoDump 完美执行 mongodump out root mongo prod DB
  • mysql-如何向列申请补助?

    用户名 撤销对数据库的选择 Person I set GRANT SELECT id ON database Person TO username localhost 不是工作 gt SELECT secret FROM Person Go
  • Pymongo 批量插入

    我正在尝试批量插入文档 但批量插入时不会插入超过 84 个文档 给我这个错误 in insert pymongo errors InvalidOperation cannot do an empty bulk insert 是否可以批量插入
  • Hibernate 对集合的查询过滤器

    我想执行以下查询 from Item i where i categoryItems catalogId catId 然而 这会产生以下异常 非法尝试取消引用集合 所以我用谷歌搜索 找到了这个 Hibernate 论坛帖子https for
  • 如何在Mysql中仅将不同的值从一个表复制到另一个表?

    我有一个大约 2 5GB 的 MySql 数据库 表 A 具有以下列 anoid query date item rank url 我刚刚创建了另一个仅包含列的表 b query and date 我想在查询列中插入所有不同的记录 及其各自
  • 如何正确转义mysql?

    我刚刚发现如果我写 select from tbl where name like foo 然后添加 foo 作为参数及其值 a 用户数据 它不会正确转义 我勒个去 它想要 a 即使我使用参数 我还是忍不住觉得我对 sql 注入持开放态度
  • 为什么我的 if 语句没有按我预期的方式工作?

    我正在尝试实现以下目标 我向我的 SQL 数据库询问使用SELECT FROM subjects 这样做之后我要求使用数组mysqli fetch assoc 在那之前一切都很好 现在的问题是 当我尝试在每个循环中修改 genero 的值
  • MySQL 按重复项从上到下排序

    我有一个lammer问题 因为我不是mysql专业人士 我有类似的字段 id color 1 red 2 green 3 yellow 4 green 5 green 6 red 我想按重复项进行分组 最常见的重复项先进行分组 所以应该这样
  • 如何使用 vitess 仅对特定表进行分片

    我创建了一个包含三个表的未分片键空间 现在我想对前两个表的键空间进行分片 但不想对第三个表进行分片 如何才能做到这一点 Vitess 文档不包含任何与此相关的信息或示例 请帮忙 Thanks vitess 中的垂直分片与水平分片类似 您应该
  • 即使使用“autoReconnect=true”,MySql JDBC 也会超时[重复]

    这个问题在这里已经有答案了 有时 我的 Java Tomcat6 Debian Squeeze 应用程序无法与 MySql 服务器通信 Tomcat 应用程序位于前端服务器上 而 MySql 位于单独的 仅限 MySql 的机器上 一个典型
  • 比特纳米。重置mysql根密码

    我如何重置 MySQL 中的 root 密码和帐户 因为我按照如何为其他服务器授予权限的说明操作 并且意外地将 root 用户 Mysql 绑定到其他 IP 地址 现在看来我无法在 localhost 上以管理员身份登录 Thanks 您有
  • Mongoose.js instance.save() 回调未触发

    var mongo require mongoose var connection mongo createConnection mongodb 127 0 0 1 test connection on error function err
  • gem install mysql:无法构建 gem 本机扩展 (Mac Lion)

    我为 Mac OS X Lion 安装了 MySQL 5 5 27 来自 dmg 现在我尝试安装 mysql gem gem install mysql Building native extensions This could take
  • 一次从多个表中删除行

    我正在尝试将 2 个查询合并为一个这样的查询 result db gt query DELETE FROM menu WHERE name new or die db gt error result db gt query DELETE F
  • 映射 mysql 中同一个表的多个值

    您好 我必须使用另一个表中的值 id 获取文本值 表 1 包含值 ID 表 2 包含名称和值 ID 表 1 SEVERITY OCCURENCE DETECTABILITY 2 3 4 表 2 id name value 1 Very Hi
  • 在 MySQL 中存储表情符号的编码问题:如何使用 Prisma ORM 在 NodeJS 中定义字符排序规则?

    亲爱的 Nodejs 专家和数据库专家 我们在 MySQL 数据库中存储表情符号和其他特殊字符时遇到问题 我们使用 Prisma 得到一个错误 这是我们使用的 ORM 参数无法从排序规则 utf8 general ci 转换为 utf8mb
  • 管理员未授权 Mongodb 执行 listDatabases 命令

    删除 mongodb 用户后 无法重新连接 mongo 没有 验证 我创造了超级用户 https docs mongodb org v2 6 reference built in roles superuser roles tomuser

随机推荐

  • keil CMSIS_DAP.DLL missing

    由于keil版本支持问题 可以下载以下版本的CMSIS DAP DLL进行替换 CMSIS DAP DLL官方下载地址 百度云下载 提取码 g8ia keil安装目录如 D Keil v5 ARM BIN 先删除原来的CMSIS DAP D
  • MySQL存储过程遍历游标用loop嵌套循环的例子

    CREATE DEFINER root PROCEDURE procInitData IN sId1 INT IN sId2 INT IN sId3 INT IN sId4 INT IN sId5 INT IN sId6 INT IN sI
  • 函数调用约定cdecl、stdcall、fastcall

    我们在编写代码的时候都会调用函数 有点函数有多个参数 例如 int test int a char b char c 上面的函数调用方式是test 10 c tinus 那么这个函数编译器是怎么知道有多少个参数 参数类型是什么了 因为函数调
  • 基于FPGA的LCD1602驱动(含代码)

    目录 LCD1602显示原理 LCD1602接口 LCD1602操作时序 1 读操作时序 2 写操作时序 LCD1602初始化 LCD1602读写数据 LCD1602显示原理 将LCD显示屏与FPGA连接之后 需要做的第一件事就是进行LCD
  • Redis底层封装细节

    日常我们程序员在使用redis做缓存的时候 很少会直接使用到RedisTemplate直接操作k v键值对 而是通过对RedisTemplate原生代码的封装 来构建我们日常便于使用习惯的代码来操作数据 这里我分享一下日常基本的对Redis
  • 【华为OD机试】矩阵元素的边界值【2023 B卷

    华为OD机试 真题 点这里 华为OD机试 真题考点分类 点这里 题目描述 给定一个N M矩阵 请先找出M个该矩阵中每列元素的最大值 然后输出这M个值中的最小值 输入描述 无 输出描述 无 备注 N和M的取值范围均为 0 100 用例1 输入
  • umi+dva+antd后台管理系统(3)---完整登录逻辑

    源码在这儿MyGithub 觉得不错留颗小星星哦 界面准备好啦 开始写登录 1 回顾一下redux是什么 redux 是一个应用数据流框架 主要解决了组件间状态共享的问题 原理是集中式管理 可以让数据更可控 react 中所有数据处理都在
  • JS加减乘除位移方法封装

    常用加减乘除等方法汇总 直接上代码 逻辑简单 代码如下 div 加减乘除位移方法汇总 div
  • 轨迹预处理(轨迹压缩)

    轨迹压缩分为在线压缩和离线压缩两类 在介绍两类压缩算法之前 本文先介绍两种 距离度量 方法 第一种距离度量方法是 垂直的欧几里得距离 如图b所示 p1 p7 p12作为压缩后的点 垂直度量 则为做垂线计算 第二种距离度量方法是 时间同步的欧
  • Dynamics CRM2011 导入解决方案报根组件插入错误的解决方法

    今天在还原一个老版本的解决方案 在导入时报根组件插入问题 Cannot add a Root Component 38974590 9322 e311 b365 00155d810a00 of type 31 because it is n
  • android: ERROR: unknown virtual device nam

    环境变量 ANDROID SDK HOME your path 设置好就没有问题了
  • 刷脸支付服务商为各行各业提供完美体验

    随着刷脸支付技术迭代更新的速度加快 其商业化应用的步伐也越来越快了 4月17日 支付宝推出第二代基于线下消费场景的刷脸支付机具 蜻蜓2 0 定价1499元 同时 新一代蜻蜓还实现了刷脸注册会员卡的功能 切中了苦于获客高成本的线下零售门店的需
  • pve 使用noVNC num lock 不同步的问题

    问题描述 在使用 pve 的noVNC 控制台 访问 WINDOWS 虚拟机时 VM 会出现num lock 状态不同步的情况 主要是由于WINDOWS 笔者这里是 SERVER2022 启动后默认关闭了 num lock 而 pve的虚拟
  • Scala中的抽象类

    1 先看下 类的层次结构 类层次结构 也称为类分类法 是一组相关的类 它们通过继承连接起来做类似的事情 层次结构的顶部可以是一个基类 它下面的所有其他类都是从中派生出来的 或者层次结构可以有多个基类 这些基类的功能稍后会在一个或多个派生类中
  • 论文阅读-Multi-attentional Deepfake Detection

    一 论文信息 题目 Multi attentional Deepfake Detection 作者团队 会议 CVPR 2021 二 背景与创新 背景 之前大多数方法将deepfake检测模型作为一个普通的二分类问题 即首先使用骨干网络提取
  • Redis面试题

    1 基本概念 1 1 常见考点 1 Redis 为何这么快 1 基于内存 2 单线程减少上下文切换 同时保证原子性 3 IO多路复用 4 高级数据结构 如 SDS Hash以及跳表等 2 为何使用单线程 因为 Redis 是基于内存的操作
  • esp32 系列芯片分类

    模组 内置芯片 Flash PSRAM 模组尺寸 mm ESP32 WROVER PCB ESP32 D0WDQ6 4M 8M 18 00 0 10 x 31 40 0 10 x 3 30 0 10 ESP32 WROVER IPEX ES
  • 微信公众号一些错误的原因错误代码41001

    微信公众号一些错误的原因错误代码41001 错误代码41001 缺少access token 碰到这种错误 请检查自己的appid和appsecret posted on 2017 05 08 18 02 baker95935 阅读 评论
  • git如何上传所有的新文件

    目的描述 新建的git项目 项目中有许多要从本地上传到git仓库的新文件 如果用git a filename的方法一个一个的添加 太费事费力 需要有命令添加所有改动 步骤 进入项目文件夹 在其中使用git bash 1 使用git clon
  • MySQL和MongoDB那些事

    什么是 MySQL 和 MongoDB MySQL 和 MongoDB 是两个可用于存储和管理数据的数据库管理系统 MySQL 是一个关系数据库系统 以结构化表格格式存储数据 相比之下 MongoDB 以更灵活的格式将数据存储为 JSON