当前位置: 首页 > news >正文

Mysql中存储引擎各种介绍以及应用场景、优缺点

概述

MySQL 提供了多种存储引擎,每种引擎有不同的特点和适用场景。以下是几种常见的 MySQL 存储引擎的详细介绍,包括它们的底层工作原理、优缺点,以及为什么 MySQL 默认选择某种引擎。

1. InnoDB

底层工作原理
  • 事务支持:InnoDB 支持 ACID 特性(原子性、一致性、隔离性、持久性),并实现了行级锁定,适合高并发的事务处理。
  • 存储格式:InnoDB 使用聚簇索引(Clustered Index)组织数据,数据按主键顺序存储在磁盘中,表的主键就是数据的物理存储顺序。
  • 崩溃恢复:InnoDB 引擎通过日志文件(redo log)实现崩溃恢复,在系统崩溃时,可以通过日志文件恢复数据。
  • 外键约束:InnoDB 支持外键约束,确保数据的完整性。
优点
  • 支持事务(ACID),保证数据一致性。
  • 支持外键,增强数据的完整性。
  • 行级锁定,可以提供更高的并发性能。
  • 自动崩溃恢复,保证数据的持久性和安全性。
  • 数据插入时,自动维护索引。
缺点
  • 比 MyISAM 慢,尤其在只读查询中,写操作更多时性能上可能较差。
  • 占用内存较多,尤其是在有很多索引的情况下。
  • 对于一些简单的读写操作,它可能并不如 MyISAM 高效。
适用场景
  • 适合需要事务支持、数据一致性和高并发的应用场景,如电商系统、银行系统、金融系统等。
为什么默认选择

MySQL 默认选择 InnoDB 引擎,因为它提供了全面的事务支持,保障数据一致性,并且在多线程环境下能够提供较好的并发性能。它适用于大多数现代应用程序,尤其是那些要求数据安全和可靠性的应用。

2. MyISAM

底层工作原理
  • 不支持事务:MyISAM 不支持事务处理,所有操作都是立即生效的,无法回滚。
  • 表级锁定:MyISAM 使用表级锁定,即在操作表时,整个表会被锁住,这会影响并发性能。
  • 存储格式:MyISAM 采用非聚簇索引,数据和索引分开存储,表的索引会单独存储在一个文件中(.MYI),数据则存储在另一个文件中(.MYD)。
  • 崩溃恢复:MyISAM 没有 InnoDB 那样的崩溃恢复机制,如果系统崩溃,数据可能会丢失。
优点
  • 查询速度快,特别是针对只读操作时,性能优越。
  • 占用内存较少,比 InnoDB 更适合大数据量的查询。
  • 对简单的 SELECT 查询效率较高。
缺点
  • 不支持事务处理,不保证数据一致性。
  • 只支持表级锁定,对于高并发的写操作性能较差。
  • 不支持外键。
  • 没有崩溃恢复机制,系统崩溃时数据容易丢失。
适用场景
  • 适用于读多写少的应用,如日志记录、统计报表等。

3. MEMORY(HEAP)

底层工作原理
  • 存储方式:MEMORY 存储引擎将数据存储在内存中,因此读写速度非常快。
  • 支持表级锁定:和 MyISAM 一样,MEMORY 使用表级锁定。
  • 不支持事务:MEMORY 不支持事务处理。
  • 数据持久性:当服务器关闭时,内存中的数据会丢失。
优点
  • 读写速度非常快,适合对性能有极高要求的应用。
  • 非常适合临时数据存储(例如,缓存)。
缺点
  • 数据不是持久化的,一旦服务器重启或崩溃,数据将丢失。
  • 仅能存储少量数据,受内存大小限制。
适用场景
  • 适用于需要快速访问、临时数据存储的场景,例如缓存表、临时结果集等。

4. CSV

底层工作原理
  • 存储方式:CSV 存储引擎将表数据存储为逗号分隔的文本文件(CSV 文件格式)。
  • 不支持索引:CSV 不支持索引,查询速度相对较慢。
  • 不支持事务和外键
优点
  • 数据文件可以方便地与其他程序(如 Excel)交换。
  • 适用于数据导出和导入场景。
缺点
  • 不支持索引,查询性能差。
  • 不支持事务,无法保证数据一致性。
  • 数据处理效率低,不适合大数据量场景。
适用场景
  • 适用于数据导入/导出、与其他应用的数据交换等场景。

5. NDB (Cluster)

底层工作原理
  • 存储方式:NDB 是 MySQL Cluster 中的存储引擎,数据存储在内存中,提供分布式的数据库服务。
  • 支持事务:NDB 支持事务,保证数据一致性。
  • 分布式存储:数据可以分布在多个节点上,实现高可用和高扩展性。
优点
  • 高可用性和高扩展性,适合分布式部署。
  • 支持事务,保证数据一致性。
  • 适合大规模、高并发的应用。
缺点
  • 配置和管理较为复杂。
  • 性能不如 InnoDB 和 MyISAM,在小规模应用场景下不适用。
适用场景
  • 适用于需要高可用性和高扩展性的分布式系统,如在线游戏、金融交易系统等。

总结

最常用的存储引擎是 InnoDB,因为它支持事务、行级锁定,并且能够提供较好的并发性能和数据一致性。MySQL 默认选择 InnoDB 引擎,主要是因为它适应了大多数现代应用的需求,特别是事务性应用的需求,比如电商、社交平台等。

为什么 MySQL 默认使用 InnoDB

  • 事务支持:InnoDB 提供了强大的事务支持,保障数据一致性和可靠性。
  • 高并发性能:行级锁定允许多个事务并发执行,而不会互相干扰。
  • 自动恢复:InnoDB 提供崩溃恢复机制,保证数据安全。
  • 外键支持:InnoDB 可以保持数据完整性,适用于复杂关系型数据库应用。

对于其他引擎(如 MyISAM),它们在特定场景下也有优势,但由于它们不支持事务或者性能上不如 InnoDB,因此不适合大多数现代应用,特别是需要数据一致性的场景。

相关文章:

Mysql中存储引擎各种介绍以及应用场景、优缺点

概述 MySQL 提供了多种存储引擎,每种引擎有不同的特点和适用场景。以下是几种常见的 MySQL 存储引擎的详细介绍,包括它们的底层工作原理、优缺点,以及为什么 MySQL 默认选择某种引擎。 1. InnoDB 底层工作原理: 事务支持&#…...

PHP 运算符

PHP 运算符 概述 PHP 是一种广泛使用的开源服务器端脚本语言,它具有丰富的运算符集,这些运算符是编写 PHP 程序的基础。运算符用于执行各种数学、逻辑和比较操作。本篇文章将详细介绍 PHP 中常用的运算符,包括算术运算符、比较运算符、逻辑运算符、赋值运算符等。 算术运…...

Vue全流程--Vue3.0与Vue2.0响应式原理对比

Vue2中数据的响应式 需要使用Vue.set这么一个api,修改数据 需要使用Vue.delete这么一个api,删除数据 数据代理这个当面的理解可以看看我前面文章Vue全流程--数据代理的理解以及在Vue中的应用-CSDN博客 Vue3中数据的响应式 Vue3使用proxy这个api实现…...

C语言学习笔记:子函数的调用实现各个位的累加和

在C语言程序学习之初,我们都会学习如何打印 hello world,在学习时我们知道了int main()是主函数,程序从main函数开始执行,这是流程控制的一部分内容。在主函数中我们想要实现一些功能,比如求各个…...

【大模型】本地部署DeepSeek-R1:8b大模型及搭建Open-WebUI交互页面

本地部署DeepSeek-R1:8b大模型 一、摘要及版本选择说明1.1 摘要1.2 版本选择 二、下载并安装Ollama三、运行DeepSeek-R1:8b大模型四、安装Open WebUI增强交互体验五、关闭Ollama开机自动启动六、DeepSeek大模型启停步骤 一、摘要及版本选择说明 1.1 摘要 作为一名对 AI 和生成…...

Python 调用 Stabilityai API在本地生成图像

Python 调用 Stabilityai API在本地生成图像 摘要功能 代码结构关键技术代码下载立即体验 摘要 本程序利用硅基流动目前的免费 stabilityai/stable-diffusion-2-1 模型API,生成图像并下载到本地,用户可以通过输入描述性提示词来获取相应的图像。使用Pyt…...

Python3中异常处理:try-finally语句的示例

一. 简介 前面一篇文章简单学习了 try-finally语句结构,执行过程、以及使用场景。文章如下: Python3中异常处理:try-finally语句-CSDN博客 本文写一些简单的示例来继续学习 try-finally语句的使用。 二. Python3中异常处理:try…...

Lua限流器的3种写法

学而不思则罔,思而不学则殆 引言 上篇文章讲解了Lua脚本,事务和Pipline之间的使用方式和性能差距,本篇文章将聚焦Lua脚本,我将用三种写法来展现如何实现一个Redis限流器 固定窗口限流 固定窗口限流也是最简单的限流算法&#x…...

基于 GEE 利用插值方法填补缺失影像

目录 1 完整代码 2 运行结果 利用GEE合成NDVI时,如果研究区较大,一个月的影像覆盖不了整个研究区,就会有缺失的地方,还有就是去云之后,有云量的地区变成空值。 所以今天来用一种插值的方法来填补缺失的影像&#xf…...

linux部署ollama+deepseek+dify

Ollama 下载源码 curl -L https://ollama.com/download/ollama-linux-amd64.tgz -o ollama-linux-amd64.tgz sudo tar -C /usr -xzf ollama-linux-amd64.tgz启动 export OLLAMA_HOST0.0.0.0:11434 ollama serve访问ip:11434看到即成功 Ollama is running 手动安装deepseek…...

在微服务中,如何使用feign在各个微服务中进行远程调用

在微服务中&#xff0c;如何使用feign在不同微服务中进行远程调用 在微服务中&#xff0c;如何使用feign在不同微服务中进行远程调用 步骤&#xff1a; 第一步&#xff1a; 引入feign依赖 <dependency><groupId>org.springframework.cloud</groupId><…...

Kafka中的KRaft算法

我们之前的Kafka值依赖于Zookeeper注册中心来启动的&#xff0c;往里面注册我们节点信息 Kafka是什么时候不依赖Zookeeper节点了 在Kafka2.8.0开始就可以不依赖Zookeeper了 可以用KRaft模式代替Zookeeper管理Kafka集群 KRaft Controller和KRaft Leader的关系 两者关系 Lea…...

vue3 -- 集成 amap(高德地图)

🍍效果 本文介绍了如何在 Vue 3 项目中集成高德地图(AMap),并使用 PoiPicker 实现地点搜索功能。 文章首先通过 AMapLoader 异步加载高德地图 API,并初始化 Map 实例。同时,借助 AMapUI 组件库引入 PoiPicker,绑定搜索输入框,实现地点选择功能。PoiPicker 监听用户的 …...

基于用户的协同过滤算法推荐

import numpy as np 计算用户之间的相似度&#xff08;这里使用余弦相似度&#xff09; def cosine_similarity(user1, user2): numerator np.dot(user1, user2) denominator np.linalg.norm(user1) * np.linalg.norm(user2) return numerator / denominator if denominato…...

4.python+flask+SQLAlchemy+达梦数据库

前提 1.liunx Centos7上通过docker部署了达梦数据库。从达梦官网下载的docker镜像。(可以参考前面的博文) 2.windows上通过下载x86,win64位的达梦数据库,只安装客户端,不安装服务端。从达梦官网下载达梦数据库windows版。(可以参考前面的博文) 这样就可以用windows的达…...

神经网络常见激活函数 4-LeakyReLU函数

文章目录 LeakyReLU函数导函数函数和导函数图像优缺点pytorch中的LeakyReLU函数tensorflow 中的LeakyReLU函数 LeakyReLU LeakyReLU&#xff1a; Leaky Rectified Linear Unit 函数导函数 LeakyReLU函数 L e a k y R e L U { x x > 0 p x x < 0 p ∈ ( 0 , 1 ) \rm …...

PHP盲盒商城系统源码 晒图+免签+短信验证+在线回收 thinkphp框架

源码介绍 PHP盲盒商城系统源码 晒图免签短信验证在线回收 thinkphp框架 源码前端uniapp开发&#xff0c;可以打包成APP&#xff08;非H5封壳&#xff09;H5&#xff0c;接其他平台支付通道&#xff0c;前后端全开源 H5盲盒首页可以直接开盒新UI 修复优化BUG&#xff0c;修复无…...

单例模式详解(Java)

单例模式详解(Java) 一、引言 1.1 概述单例模式的基本概念和重要性 单例模式是一种常用的软件设计模式,它确保一个类在整个应用程序中只有一个实例,并提供一个全局访问点来访问这个唯一实例。这种模式在资源管理、配置设置和日志记录等方面非常有用,因为它们通常只需要…...

2025年度Python最新整理的免费股票数据API接口

在2025年这个充满变革与机遇的年份&#xff0c;随着金融市场的蓬勃发展&#xff0c;量化交易逐渐成为了投资者们追求高效、精准交易的重要手段。而在这个领域中&#xff0c;一个实时、准确、稳定的股票API无疑是每位交易者梦寐以求的工具。 现将200多个实测可用且免费的专业股票…...

2.10学习总结

今天接着看了数据结构&#xff0c;但是跟指针有关的看不懂&#xff08;万恶的指针&#xff09;&#xff0c;写了考试的补题。 #include <stdio.h> #include <stdlib.h> int a[1000005]; int main() {int n,i,x0;scanf("%d",&n);for(i1;i<n;i){x;i…...

微软PowerBI考试 PL300-选择 Power BI 模型框架【附练习数据】

微软PowerBI考试 PL300-选择 Power BI 模型框架 20 多年来&#xff0c;Microsoft 持续对企业商业智能 (BI) 进行大量投资。 Azure Analysis Services (AAS) 和 SQL Server Analysis Services (SSAS) 基于无数企业使用的成熟的 BI 数据建模技术。 同样的技术也是 Power BI 数据…...

现代密码学 | 椭圆曲线密码学—附py代码

Elliptic Curve Cryptography 椭圆曲线密码学&#xff08;ECC&#xff09;是一种基于有限域上椭圆曲线数学特性的公钥加密技术。其核心原理涉及椭圆曲线的代数性质、离散对数问题以及有限域上的运算。 椭圆曲线密码学是多种数字签名算法的基础&#xff0c;例如椭圆曲线数字签…...

IT供电系统绝缘监测及故障定位解决方案

随着新能源的快速发展&#xff0c;光伏电站、储能系统及充电设备已广泛应用于现代能源网络。在光伏领域&#xff0c;IT供电系统凭借其持续供电性好、安全性高等优势成为光伏首选&#xff0c;但在长期运行中&#xff0c;例如老化、潮湿、隐裂、机械损伤等问题会影响光伏板绝缘层…...

SpringCloudGateway 自定义局部过滤器

场景&#xff1a; 将所有请求转化为同一路径请求&#xff08;方便穿网配置&#xff09;在请求头内标识原来路径&#xff0c;然后在将请求分发给不同服务 AllToOneGatewayFilterFactory import lombok.Getter; import lombok.Setter; import lombok.extern.slf4j.Slf4j; impor…...

dify打造数据可视化图表

一、概述 在日常工作和学习中&#xff0c;我们经常需要和数据打交道。无论是分析报告、项目展示&#xff0c;还是简单的数据洞察&#xff0c;一个清晰直观的图表&#xff0c;往往能胜过千言万语。 一款能让数据可视化变得超级简单的 MCP Server&#xff0c;由蚂蚁集团 AntV 团队…...

高效线程安全的单例模式:Python 中的懒加载与自定义初始化参数

高效线程安全的单例模式:Python 中的懒加载与自定义初始化参数 在软件开发中,单例模式(Singleton Pattern)是一种常见的设计模式,确保一个类仅有一个实例,并提供一个全局访问点。在多线程环境下,实现单例模式时需要注意线程安全问题,以防止多个线程同时创建实例,导致…...

Aspose.PDF 限制绕过方案:Java 字节码技术实战分享(仅供学习)

Aspose.PDF 限制绕过方案&#xff1a;Java 字节码技术实战分享&#xff08;仅供学习&#xff09; 一、Aspose.PDF 简介二、说明&#xff08;⚠️仅供学习与研究使用&#xff09;三、技术流程总览四、准备工作1. 下载 Jar 包2. Maven 项目依赖配置 五、字节码修改实现代码&#…...

LRU 缓存机制详解与实现(Java版) + 力扣解决

&#x1f4cc; LRU 缓存机制详解与实现&#xff08;Java版&#xff09; 一、&#x1f4d6; 问题背景 在日常开发中&#xff0c;我们经常会使用 缓存&#xff08;Cache&#xff09; 来提升性能。但由于内存有限&#xff0c;缓存不可能无限增长&#xff0c;于是需要策略决定&am…...

从面试角度回答Android中ContentProvider启动原理

Android中ContentProvider原理的面试角度解析&#xff0c;分为​​已启动​​和​​未启动​​两种场景&#xff1a; 一、ContentProvider已启动的情况 1. ​​核心流程​​ ​​触发条件​​&#xff1a;当其他组件&#xff08;如Activity、Service&#xff09;通过ContentR…...

ubuntu22.04 安装docker 和docker-compose

首先你要确保没有docker环境或者使用命令删掉docker sudo apt-get remove docker docker-engine docker.io containerd runc安装docker 更新软件环境 sudo apt update sudo apt upgrade下载docker依赖和GPG 密钥 # 依赖 apt-get install ca-certificates curl gnupg lsb-rel…...