MySQL存储引擎对比及选择指南
MySQL 存储引擎是数据库底层管理数据存储和操作的核心组件,不同存储引擎在事务支持、性能、锁机制、存储方式等方面存在显著差异。以下是常见存储引擎的对比及其适用场景:
1. InnoDB
- 事务支持:支持 ACID 事务(
COMMIT
/ROLLBACK
)。 - 锁机制:行级锁(默认),支持高并发写入。
- 外键:支持外键约束(Foreign Key)。
- 存储结构:
- 数据按主键聚簇索引存储(主键查询高效)。
- 支持表空间(Tablespace),可跨文件存储。
- 崩溃恢复:提供崩溃后的安全恢复机制。
- 适用场景:
- OLTP(在线事务处理):如订单系统、银行交易。
- 高并发读写、需要事务保证一致性的场景。
- 缺点:相比 MyISAM,存储空间占用稍高。
2. MyISAM
- 事务支持:不支持事务。
- 锁机制:表级锁(并发写入性能差)。
- 外键:不支持外键。
- 存储结构:
- 数据文件(
.MYD
)、索引文件(.MYI
)、表结构文件(.frm
)分离。 - 支持全文索引(FULLTEXT)。
- 数据文件(
- 性能:
- 读操作速度快(适合读多写少场景)。
- 写入时表锁会导致并发性能下降。
- 适用场景:
- 只读或读多写少的应用(如日志系统、静态内容管理)。
- 需要全文索引的旧版本 MySQL(5.6 前)。
- 缺点:
- 崩溃后数据易损坏,需手动修复(
REPAIR TABLE
)。 - 不支持事务和行级锁。
- 崩溃后数据易损坏,需手动修复(
3. Memory
- 数据存储:数据完全存储在内存中,重启后丢失。
- 锁机制:表级锁。
- 索引支持:支持哈希索引(HASH)和 B-Tree 索引。
- 性能:读写速度极快(适合临时数据缓存)。
- 适用场景:
- 临时表、会话缓存、快速查找表。
- 数据无需持久化的场景。
- 缺点:
- 内存限制(表大小受
max_heap_table_size
限制)。 - 不支持 TEXT/BLOB 类型。
- 内存限制(表大小受
4. Archive
- 存储方式:高压缩存储(数据压缩比高,占空间小)。
- 写入性能:仅支持 INSERT 和 SELECT,不支持 UPDATE/DELETE。
- 锁机制:行级锁(仅对 INSERT 有效)。
- 适用场景:
- 归档存储(如历史日志、审计数据)。
- 需要高压缩且极少查询的数据。
- 缺点:查询性能较低,不支持索引。
5. CSV
- 存储方式:数据以 CSV 格式存储(纯文本)。
- 特点:
- 可直接用文本编辑器查看数据。
- 不支持索引、事务和分区。
- 适用场景:数据导入/导出(如与外部系统交换数据)。
6. Blackhole
- 存储方式:不存储任何数据,写入的数据直接被丢弃。
- 适用场景:
- 数据复制的中继(主从架构中过滤某些操作)。
- 测试写入性能(不实际消耗存储资源)。
对比总结
特性 | InnoDB | MyISAM | Memory | Archive |
---|---|---|---|---|
事务支持 | ✔️ | ❌ | ❌ | ❌ |
行级锁 | ✔️ | ❌(表锁) | ❌(表锁) | ✔️(仅 INSERT) |
外键 | ✔️ | ❌ | ❌ | ❌ |
崩溃恢复 | ✔️ | ❌ | ❌ | ❌ |
压缩存储 | ❌ | ❌ | ❌ | ✔️ |
全文索引 | ✔️(5.6+) | ✔️ | ❌ | ❌ |
适用场景 | 高并发事务 | 读多写少 | 内存临时表 | 归档存储 |
如何选择存储引擎?
- 默认选择:优先使用 InnoDB(MySQL 5.5+ 默认引擎),支持事务和行级锁。
- 读密集型:若无需事务且读多写少,可考虑 MyISAM。
- 临时数据:使用 Memory 引擎(如会话缓存)。
- 归档数据:使用 Archive 引擎(高压缩存储)。
- 特殊需求:根据场景选择 CSV 或 Blackhole。
通过 SHOW ENGINES;
可查看当前 MySQL 支持的存储引擎列表及其状态。
相关文章:
MySQL存储引擎对比及选择指南
MySQL 存储引擎是数据库底层管理数据存储和操作的核心组件,不同存储引擎在事务支持、性能、锁机制、存储方式等方面存在显著差异。以下是常见存储引擎的对比及其适用场景: 1. InnoDB 事务支持:支持 ACID 事务(COMMIT/ROLLBACK&am…...
【IDEA问题】springboot本地启动应用报错:程序包不存在;找不到符号
问题: springboot本地启动应用报错: 程序包xxx不存在;找不到符号 解决方案: 1.确保用maven重新导入依赖 2.删除.idea文件夹 3.invalidate caches里,把能选择的都勾选上,然后清除缓存重启 4.再在上方工具栏…...

PETR- Position Embedding Transformation for Multi-View 3D Object Detection
旷视 ECCV 2022 纯视觉BEV方案transformer网络3D检测 paper:[2203.05625] PETR: Position Embedding Transformation for Multi-View 3D Object Detection code:GitHub - megvii-research/PETR: [ECCV2022] PETR: Position Embedding Transformation …...

Prompt Tuning与自然语言微调对比解析
Prompt Tuning 与输入提示词自然语言微调的区别和联系 一、核心定义与区别 维度Prompt Tuning(提示微调)输入提示词自然语言微调本质优化连续向量空间中的提示嵌入(不可直接阅读)优化离散自然语言文本(人类可理解)操作对象模型输入嵌入层的连续向量(如WordEmbedding)自…...
二十七、面向对象底层逻辑-SpringMVC九大组件之HandlerAdapter接口设计
在 Spring MVC 框架中,HandlerAdapter 是一个看似低调却极为关键的组件。它的存在,不仅解决了不同类型处理器(Handler)的调用难题,更体现了框架设计中对解耦、扩展性和模块化的深刻思考。本文将从接口设计的角度&#…...

QT软件开发环境及简单图形的绘制-图形学(实验一)-[成信]
对于软件的安装这里就不多介绍了。 本文章主要是根据本校图形学的实验知道来做。 创建一个简单的计算机图形学程序 第一步:创建项目及配置 这里创建的项目名和类名尽量和我的一样,避免后面直接复制我的代码时会出现一些名字上面的错误。QtWidgetsAppl…...
项目部署一次记录
链路:(用户)客户端 → Nginx:192.168.138.100→ Tomcat (程序):192.168.138.101→ MySQL/Redis 打开数据库:systemctl start mysqld 重启网络: systemctl restart NetworkManager 关闭防火墙&am…...
单例模式,饿汉式,懒汉式,在java和spring中的体现
目录 饿汉式单例模式 懒汉式单例模式 Spring中的单例模式 关键差异对比 在Java和Spring中的应用场景 手写案例 单例模式是一种创建型设计模式,其核心在于确保一个类仅有一个实例,并提供一个全局访问点来获取该实例。下面将详细介绍饿汉式和懒汉式…...

一文带你彻底理清C 语言核心知识 与 面试高频考点:从栈溢出到指针 全面解析 附带笔者手写2.4k行代码加注释
引言:C 语言的魅力与挑战 从操作系统内核到嵌入式系统,从高性能计算到网络编程,C 语言高效、灵活和贴近硬件的特性,始终占据着不可替代的地位。然而,C 语言的强大也伴随着较高的学习曲线,尤其是指针、内存管…...
【Redis】第1节|Redis服务搭建
一、Redis 基础概念 核心功能 内存数据库,支持持久化(RDB/AOF)、主从复制、哨兵高可用、集群分片。常用场景:缓存、分布式锁、消息队列、计数器、排行榜等。 安装环境 依赖 GCC 环境(C语言编译)࿰…...

数据结构第5章 树与二叉树(竟成)
第 5 章 树与二叉树 【考纲内容】 1.树的基本概念 2.二叉树 (1)二叉树的定义及其主要特征 (2)二叉树的顺序存储结构和链式存储结构 (3)二叉树的遍历 (4)线索二叉树的基本概念和构造 …...

# 深入解析BERT自然语言处理框架:原理、结构与应用
深入解析BERT自然语言处理框架:原理、结构与应用 在自然语言处理(NLP)领域,BERT(Bidirectional Encoder Representations from Transformers)框架的出现无疑是一个重要的里程碑。它凭借其强大的语言表示能…...
ai学习--python部分-1.变量名及命名空间的存储
初学代码时总有一个问题困扰我:a 10 # a指向地址0x1234(存储10) 变量a的值10存储在0x1234,那么变量a需要存储吗?a又存储在什么地址呢 目录 1. 命名空间的本质 2. 命名空间的内存占用 3. …...

Cadence学习笔记之---PCB过孔替换、封装更新,DRC检查和状态查看
目录 01 | 引 言 02 | 环境描述 03 | 过孔替换 04 | 封装更新 05 | PCB状态查看 06 | DRC检查 07 | 总 结 01 | 引 言 终于终于来到了Cadence学习笔记的尾声! 在上一篇文章中,讲述了如何布线、如何铺铜,以及布线、铺铜过程中比较重要…...
Java基础 Day21
一、Stream 流 思想:流水线式思想 1、获取流对象(将数据放到流中) (1)集合获取 Stream 流对象 使用Collection接口的默认方法 default Stream<E> stream() 获取当前集合对象的 Stream 流(单列集…...

系统开发和运行知识
软件生存周期 软件生存周期包括可行性分析与项目开发计划、需求分析、概要设计、详细设计、编码和单元测试、综合测试及维护阶段。 1、可行性分析与项目开发计划 主要任务是确定软件的开发目标及可行性。该阶段应该给出问题定义、可行性分析和项目开发计划。 2、需求分析 需求…...
Elasticsearch 分片驱逐(Shard Exclusion)方式简析:`_name`、`_ip`、`_host`
在日常运维 Elasticsearch 集群过程中,常常需要将某个节点上的分片迁移出去,例如下线节点、腾出资源或进行维护操作。Elasticsearch 提供了简单直观的 shard exclusion 参数来实现这一目的,主要通过以下三个配置项: cluster.rout…...

【C++高级主题】异常处理(四):auto_ptr类
目录 一、auto_ptr 的诞生:为异常安全的内存分配而设计 1.1 传统内存管理的痛点 1.2 auto_ptr 的核心思想:RAII 与内存绑定 1.3 auto_ptr 的基本定义(简化版) 二、auto_ptr 的基本用法:将指针绑定到智能对象 2.1…...

STM32CubeMX配置使用通用定时器产生PWM
一、定时器PWM功能简介 定时器,顾名思义,就是定时的功能,定时器在单片机中算是除GPIO外最基本的外设。在ST中,定时器分为几种,基础定时器,通用定时器,高级定时器和低功耗定时器。其中定时器除了…...

WebSphere Application Server(WAS)8.5.5教程第十四讲:JPA
一、JPA 以下是对 JPA(Java Persistence API) 的深入详解,适用于具备一定 Java EE / Jakarta EE 背景的开发者,尤其是对数据持久化机制感兴趣的人员。 1、什么是 JPA? Java Persistence API(JPA…...

Linux系统调用深度剖析
Linux系统调用深度剖析与实践案例 目录 Linux系统调用深度剖析与实践案例 一、Linux系统调用概述 二、进程管理相关系统调用 1. fork():进程克隆与多任务处理 2. exec系列:程序加载与替换 3. wait/waitpid:进程状态同步 三、文件操作相关系统调用 1. 文件描述符操作…...

动态规划-918.环形子数组的最大和-力扣(LeetCode)
一、题目解析 听着有点复杂,这里一图流。 将环形问题转化为线性问题。 二、算法原理 1.状态表示 2.状态转移方程 详细可以移步另一篇博客,53. 最大子数组和 - 力扣(LeetCode) 3.初始化 由于计算中需要用到f[i-1]和g[i-1]的值&…...
Docker 镜像标签(Tag)规范与要求
Docker 镜像标签(Tag)规范与要求 背景 目前主流云厂商,如阿里云、百度云和腾讯云,均提供租户使用的镜像仓库服务。 各个厂商要求可能不太一样,比如华为:https://doc.hcs.huawei.com/zh-cn/usermanual/swr/swr_faq_0017.html 样…...

STM32:Modbus通信协议核心解析:关键通信技术
知识点1【 Modbus通信】 1、Modbus的概述 Modbus是OSI模型第七层的应用层报文传输协议 协议:说明有组包和解包的过程 2、通信机制 Modelbus是一个请求/应答协议 通信机制:主机轮询,从机应答的机制。每个从设备有唯一的地址,主…...

线程封装与互斥
目录 线程互斥 进程线程间的互斥相关背景概念 互斥量mutex 互斥量的接口 初始化互斥量有两种方法: 销毁互斥量 互斥量加锁和解锁 改进售票系统 互斥量实现原理探究 互斥量的封装 线程互斥 进程线程间的互斥相关背景概念 临界资源:多线程执行流共…...
鸿蒙OSUniApp 开发实时天气查询应用 —— 鸿蒙生态下的跨端实践#三方框架 #Uniapp
使用 UniApp 开发实时天气查询应用 —— 鸿蒙生态下的跨端实践 在移动互联网时代,天气应用几乎是每个人手机中的"标配"。无论是出行、旅游还是日常生活,实时获取天气信息都极为重要。本文将以"实时天气查询应用"为例,详…...
第十一天 5G切片技术在车联网中的应用
前言 在自动驾驶汽车每天产生4TB数据的时代,传统的移动网络已难以满足车联网的海量连接需求。中国移动2023年实测数据显示,某智能网联汽车示范区在传统5G网络下,紧急制动指令的传输延迟高达65ms,而5G网络切片技术将这个数值降低到…...

Spring AI 系列之一个很棒的 Spring AI 功能——Advisors
1. 概述 由AI驱动的应用程序已成为我们的现实。我们正在广泛地实现各种RAG应用程序、提示API,并利用大型语言模型(LLM)创建项目。借助 Spring AI,我们可以更快速地完成这些任务。 在本文中,我们将介绍一个非常有价值…...

Vue3 + TypeScript + el-input 实现人民币金额的输入和显示
输入人民币金额的参数要求: 输入要求: 通过键盘,只允许输入负号、小数点、数字、退格键、删除键、方向左键、方向右键、Home键、End键、Tab键;负号只能在开头;只保留第一个小数点;替换全角输入的小数点&a…...

2.1 C++之条件语句
学习目标: 理解程序的分支逻辑(根据不同条件执行不同代码)。掌握 if-else 和 switch 语句的用法。能编写简单的条件判断程序(如成绩评级、游戏选项等)。 1 条件语句的基本概念 什么是条件语句? 程序在执…...