快速了解:MySQL InnoDB和MyISAM的区别

news2025/1/11 2:22:32

目录

  • 一、序言
  • 二、InnoDB和MyISAM对比
    • 1、InnoDB特性支持如下
    • 2、MyISAM特性支持如下
  • 三、两者核心区别
    • 1、事务支持
    • 2、锁机制
    • 3、索引结构
    • 4、缓存机制
    • 5、故障恢复
    • 6、使用场景

一、序言

在MySQL 8.0中,InnoDB是默认的存储引擎。除了InnoDB,MySQL还支持其它的存储引擎,比如MyISAMMEMORYCSVARCHIVEBLACKHOLEMERGEFEDERATE等。

除非在创建表的时候手动指定存储引擎,不然创建的表都是InnoDB管理的表。

今天我们根据官方文档详细聊聊InnoDB和MyISAM的区别。

二、InnoDB和MyISAM对比

1、InnoDB特性支持如下

特性是否支持
B-tree indexes
备份/时间点恢复是 (Server层实现而不是存储引擎层)
集群数据库支持
聚簇索引
压缩数据
数据缓存
加密数据是(Server层经过加密函数实现)
外键支持
全文搜索索引是(MySQL 5.6及以上版本支持)
空间数据类型支持
空间索引支持是(MySQL 5.7及以上版本支持)
哈希索引
索引缓存
锁粒度行级
MVCC
复制支持是 (Server层实现,而不是存储引擎层)
存储上限64TB
T-tree索引
事务
数据字典更新统计

2、MyISAM特性支持如下

特性是否支持
B-tree indexes
备份/时间点恢复是 (Server层实现而不是存储引擎层)
集群数据库支持
聚簇索引
压缩数据
数据缓存
加密数据是(Server层经过加密函数实现)
外键支持
全文搜索索引
空间数据类型支持
空间索引支持
哈希索引
索引缓存
锁粒度表级
MVCC
复制支持是 (Server层实现,而不是存储引擎层)
存储上限256TB
T-tree索引
事务
数据字典更新统计

三、两者核心区别

1、事务支持

  • InnoDB:支持事务,提供ACID特性,适合需要事务保证的应用。
  • MyISAM:不支持事务,每次操作视为独立才做,不保证原子性,适合读多写少的应用。

2、锁机制

  • InnoDB:支持行级锁和表级锁,行级锁粒度更小,适合高并发场景。
  • MyISAM:只支持表级锁,读写操作都会锁表,适合读多写少的场景。

3、索引结构

  • InnoDB:使用聚簇索引,数据文件和索引文件合并在一个.ibd文件,提高查询效率。
  • MyISAM:使用非聚簇索引,数据文件和索引文件是分开的,分为.MYD(MyData).MYI(MYIndex)文件,索引文件较大,但查询速度快。

4、缓存机制

  • InnoDB:有自己的Buffer Pool,用于缓存数据和索引,减少磁盘访问。
  • MyISAM:只缓存索引文件,不缓存数据文件,每次查询都需要从磁盘读取访问。

5、故障恢复

  • InnoDB:通过Redo log和Undo log可以进行数据的恢复和回滚,适合需要保证数据一致性和持久性的场景。
  • MyISAM:故障恢复能力较弱,可能导致数据丢失。

6、使用场景

  • InnoDB:适用于对事务要求较高、数据一致性和完整性要求严格的应用场景,如银行、电商系统等。
  • MyISAM:适用于一些对事务要求不高、以读为主的应用场景,如数仓、报表系统等。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2184033.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SQL - 函数

1. 操作类函数 这一类函数针对数据结构,表格进行筛选操作 1.1 GROUP BY 根据某个单一列中属性或者多个列对结果集进行分组 SELECT column1, SUM(column2) FROM table GROUP BY column1; 上述代码将所选择列进行column1中的属性分组,作为每一行的索引…

如何在idea使用RabbitMQ

一.RabbitMQ的安装和访问 1.在linux虚拟机安装RabbitMQ docker run -d --name rabbitmq -p 5671:5671 -p 5672:5672 -p 4369:4369 -p 25672:25672 -p 15671:15671 -p 15672:15672 rabbitmq:3.9.9-management 2.启动RabbitMQ docker start rabbitmq 3.访问 RabbitMQ网页 在自…

【Python】Uvicorn:Python 异步 ASGI 服务器详解

Uvicorn 是一个为 Python 设计的 ASGI(异步服务器网关接口)Web 服务器。它填补了 Python 在异步框架中缺乏一个最小化低层次服务器/应用接口的空白。Uvicorn 支持 HTTP/1.1 和 WebSockets,是构建现代异步Web应用的强大工具。 ⭕️宇宙起点 &a…

C++网络编程之IP地址和端口

概述 IP地址和端口共同定义了网络通信中的源和目标。IP地址负责将数据从源设备正确地传输到目标设备,而端口则确保在目标设备上数据被交付到正确的应用或服务。因此,在网络编程中,IP地址和端口是密不可分的两个概念,共同构成了网络…

Why RTSP?RTSP播放器优势探究

RTSP优势探究 好多开发者搞不清楚,低延迟的传输,到底是走RTMP、WebRTC还是RTSP?如果走RTSP,RTSP播放器的优势有哪些?能否达到期望的延迟?答案是肯定的,废话不多说,上效果图&#xf…

Power apps:一次提交多项申请

1、添加一个Form,导入sharepoint列表,添加确认,继续,取消按钮 2、在页面的onvisible属性中添加 Set(applynumber,Last(付款申请表).申请编号1); #定义一个申请编号变量,每次申请,就将列表最后一个…

医疗陪诊APP开发实战:从互联网医院系统源码开始

本文将从互联网医院系统源码出发,深入探讨医疗陪诊APP的开发实战。 一、从互联网医院系统源码入手 开发医疗陪诊APP的基础在于互联网医院系统的源码。互联网医院系统通常包括以下几个模块: 1.用户管理:用户注册、登录、信息管理等功能。 …

C++继承的三种方式[ACCESS]

C继承的定义 两个类的继承关系在派生类中声明,派生类定义使用以下语法: class DerivedClass: [ACCESS] BaseClass{ /…/ }; 冒号(:)后的[ACCESS]是继承的最高权限级别符,可以是以下三个值(存取权限级别&am…

fpga系列 硬件(时序收敛):触发器建立时间(setuptime)

触发器 电平触发、边沿触发和脉冲触发是三种主要的触发形式。always (posedge clk or negedge rst_n) 是一个典型的 Verilog 语句,用于定义一个带复位的触发器。D触发器是一种基本的数字存储元件,主要用于数据存储和时序控制。 D触发器的建立时间和保持…

Zabbix自动发现SNMP主机

前言 利用Zabbix监控DELL R740主机硬件,监控通过自动发现主机,链接SNMP监控模板 一、配置自动发现 自动发现脚本 cat discovery_host.pyfrom os.path import abspath, dirname, join import json import sysreload(sys) sys.setdefaultencoding(utf-8…

【2024】前端学习笔记11-网页布局-弹性布局flex

学习笔记 网页布局弹性布局:flex案例:flex布局案例 网页布局 在页面布局中,display属性用于设置一个元素的显示方式。它可以指定元素是作为块级元素、内联元素还是充当表格元素显示。 display的常见属性值: block:将…

前端——Ajax和jQuery

一、Ajax Ajax即“Asynchronous Javascript And XML”(异步 JavaScript 和 XML), 通过 JS 异步的向服务器发送请 求并接收响应数据。 同步访问:当客户端向服务器发送请求时,服务器在处理的过程中,浏览器…

AutoGen实现多代理-Planning_and_Stock_Report_Generation(六)

1. 案例背景 本节内容是构建Agent组,通过广播模式,实现管理者对agent工作流的管理。本实验链接:传送门 2. 代码实践 2.1 环境设置 llm_config{"model": "gpt-4-turbo"}# 工作任务描述 task "Write a blogpost a…

【CSS3】css开篇基础(1)

1.❤️❤️前言~🥳🎉🎉🎉 Hello, Hello~ 亲爱的朋友们👋👋,这里是E绵绵呀✍️✍️。 如果你喜欢这篇文章,请别吝啬你的点赞❤️❤️和收藏📖📖。如果你对我的…

【树莓派系列】树莓派首次开机配置

树莓派首次开机配置 文章目录 树莓派首次开机配置1.镜像烧录2.开启串口调试1.无屏幕2.有屏幕3.串口登录系统 3.配置网络VNC与SSH的区别 4.更新vim5.固定IP地址6.开启SSH,网络登录开发板7.xrdp图形化登录开发板XRDP与VNC区别8.更新国内下载镜像源9.vscode连接开发板1…

C语言 | Leetcode C语言题解之第450题删除二叉搜索树中的节点

题目: 题解: struct TreeNode* deleteNode(struct TreeNode* root, int key){struct TreeNode *cur root, *curParent NULL;while (cur && cur->val ! key) {curParent cur;if (cur->val > key) {cur cur->left;} else {cur c…

OpenAi FunctionCalling 案例详解

源码详细讲解 pdf 及教学视频下载链接:点击这里下载 FunctionCalling的单一函数调用 天气预报查询(今天长沙的天气如何?) import json import requests from openai import OpenAIclient OpenAI()location "长沙"…

`git restore` 和 `git checkout` 用于丢弃工作区的改动, `git switch` 和 `git checkout` 用来切换分支

git restore 和 git checkout 都可以用于丢弃工作区的改动 但它们有一些区别,尤其是在 Git 2.23 引入了新的命令后。 主要区别 git checkout 是一个多用途命令: 它用于切换分支。它还可以用于恢复工作区中特定文件的更改。由于功能过于复杂&#xff0c…

Cortex微控制器软件接口标准(CMSIS)

Cortex微控制器软件接口标准 目前,软件开发已经是嵌入式系统行业公认的主要开发成本,通过将所有Cortex-M芯片供应商产品的软件接口标准化,能有效降低这一成本,尤其是进行新产品开发或者将现有项目或软件移植到基于不同厂商MCU的产…

Golang | Leetcode Golang题解之第450题删除二叉搜索树的节点

题目: 题解: func deleteNode(root *TreeNode, key int) *TreeNode {var cur, curParent *TreeNode root, nilfor cur ! nil && cur.Val ! key {curParent curif cur.Val > key {cur cur.Left} else {cur cur.Right}}if cur nil {retur…