mysql的Memory引擎的深入了解

article/2025/8/2 1:56:41

目录

1、Memory引擎介绍

2、Memory内存结构

3、内存表的锁

4、持久化

5、优缺点

6、应用


前言

        Memory 存储引擎 是 MySQL 中一种高性能但非持久化的存储方案,适合临时数据存储缓存场景。其核心优势在于极快的读写速度,需注意数据丢失风险内存占用限制

        在使用时需结合业务需求,合理配置参数(如 max_heap_table_size),并避免将其用于需要持久化或事务支持的场景。


1、Memory引擎介绍

        MySQL Memory引擎用于创建内存中的表,数据存储在内存,访问快速但重启后数据丢失。通过--init-file启动mysqld可持久化数据。

        内存表默认使用hash索引,适用于临时表,但有限制如不支持BLOB/TEXT,且所有用户可见。可以利用其速度优势创建内存临时表替代MyISAM临时表。

  • 数据完全存储在内存中
    • 数据和索引均存在于内存中,无磁盘 I/O 开销。
    • 重启 MySQL 或异常关闭后,数据会丢失。
  • 存储限制
    • 受 max_heap_table_size 和 tmp_table_size 参数限制。
    • 不支持大字段(如 TEXTBLOB)。
  • 存储结构
    • 仅支持哈希索引,适合等值查询(=),不支持范围查询(><BETWEEN)。
  • 不支持事务

2、Memory内存结构

    仅支持哈希索引,数据存放将索引和数据分开存储。

        索引采用Hash的形式,存放主键id和指向数据的指针,而数据则按插入顺序存放。称这种数据组织方式为堆组织方式。

如下图所示:

特点:且数据的hash的key也不支持有序,value也没指定的顺序。

3、内存表的锁

        内存表不支持行锁,只支持表锁。如果一张表有更新,就会堵住其它所有在这个表上的读写操作。导致了Memory存储引擎在进行并发操作时会造成大量的阻塞,效率不高。

示例:

        在这个执行序列里, session A的update语句要执行50秒, 在这个语句执行期间session B的查询会进入锁等待状态。 session C的show processlist 结果输出如下:

        跟行锁比起来, 表锁对并发访问的支持不够好。 


4、持久化

如果数据库重启,所有的内存表都会被清空。

在主备场景:

看一下下面这个时序:

  1. 业务正常访问主库。
  2. 备库硬件升级, 备库重启, 内存表t1内容被清空。
  3. 备库重启后, 客户端发送一条update语句, 修改表t1的数据行, 这时备库应用线程就会报错“找不到要更新的行”。

⚠️注意:内存表可能导致主备不一致。

 解决方案:

        所以, 担心主库重启之后, 出现主备不一致, MySQL在实现上做了这样一件事儿: 在数据库重启之后, 往binlog里面写入一行DELETE FROM t1。

        在备库重启的时候, 备库binlog里的delete语句就会传到主库, 然后把主库内存表的内容删除。这样使用的时候就会发现, 主库的内存表数据突然被清空了。

无论是M-S架构,还是双M架构,内存表都不适合在生产环境上作为普通数据表使用。


5、优缺点


6、应用

设置:

set sql_log_bin=off;
alter table tbl_name engine=innodb;

假设有以下两张表t1、t2,其中表t1是Memory引擎,表t2是InnoDB引擎。

-- 创建表t1,t2,分别使用Memory引擎和InnoDB引擎;
create table t1(id int primary key,c int) engine=Memory;
create table t2(id int primary key,c int) engine=innodb;
insert into t1values(1,1),(2,2),(3,3),(4,4),(5,5),(6,6),(7,7),(8,8),(9,9),(0,0);
insert into t2values(1,1),(2,2),(3,3),(4,4),(5,5),(6,6),(7,7),(8,8),(9,9),(0,0);-- 执行查询语句,得到结果如下图:
select * from t1;
select * from t2;

结果如下:

内存表t1的返回结果里面0在最后一行, 而InnoDB表t2的返回结果里0在第一行。

        表t1是Memory表,而Memory表的数据和索引是分开的。

数据组织方式如下:

        由上可知,内存表的数据部分以数组的方式单独存放,而主键id索引里,存的是每个数据的位置。主键id是hash索引,可以看到索引上的key并不是有序的。

        在对表t1执行select *的时候, 走的是全表扫描, 也就是顺序扫描这个数组。 因此, 0就是最后一个被读到, 并放入结果集的数据。

        表t2是InnoDB表,其数据就放在主键索引树上,主键索引是B+树。

数据组织方式如下:

        主键索引上的值是有序存储的,在执行select *的时候, 就会按照叶子节点从左到右扫描, 所以得到的结果里, 0就出现在第一行。


关于三种不同引擎的总结


参考文章:

1、MySQL查询执行(八):Memory引擎_mysql memory引擎-CSDN博客


http://www.hkcw.cn/article/vHxYhbxMTa.shtml

相关文章

QNAP MEMOS 域名访问 SSL(Lucky)

注意&#xff1a;下述是通过ssh、docker-compose方式安装docker的&#xff0c;不是直接在container station中安装的哈&#xff01;&#xff01;&#xff01; 一、编辑docker-compose.yml文件 用“#”号标识的&#xff0c;在保存文件的时候建议去掉&#xff0c;不然有时候会出…

BioID技术在宿主-病原体相互作用领域的应用

细菌感染是全球公共卫生的重大威胁&#xff0c;而抗生素耐药性的提升使我们迫切需要深入了解宿主 -病原体相互作用。细菌病原体通过分泌效应蛋白&#xff0c;操纵宿主细胞以建立感染。这些效应蛋白通过与宿主蛋白相互作用&#xff0c;改变宿主细胞功能&#xff0c;但传统研究方…

解析楼宇自控系统:分布式结构的核心特点与优势展现

在建筑智能化发展的进程中&#xff0c;楼宇自控系统作为实现建筑高效运行与管理的关键&#xff0c;其系统结构的选择至关重要。传统的集中式楼宇自控系统在面对日益复杂的建筑环境和多样化的管理需求时&#xff0c;逐渐暴露出诸多弊端&#xff0c;如可靠性低、扩展性差、响应速…

SAP Business One:无锡哲讯科技助力中小企业数字化转型的智慧之选

数字化转型&#xff0c;中小企业的必经之路 在当今竞争激烈的商业环境中&#xff0c;数字化转型已不再是大型企业的专利&#xff0c;越来越多的中小企业开始寻求高效、灵活的管理系统来优化业务流程、提升运营效率。作为全球领先的企业管理软件&#xff0c;SAP Business One…

Python基于Django的校园打印预约系统(附源码,文档说明)

博主介绍&#xff1a;✌IT徐师兄、7年大厂程序员经历。全网粉丝15W、csdn博客专家、掘金/华为云//InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;&#x1f3…

身份证发给别人怎么加水印?赛文奥特曼身份证添加水印教程

我们经常需要使用身份证照片进行身份验证、资料提交等操作。然而&#xff0c;直接将身份证照片发送给他人或上传到网络存在一定的信息泄露风险。为了更好地保护个人隐私&#xff0c;我们可以使用 简鹿水印助手 这款工具&#xff0c;在身份证照片上添加专属水印&#xff0c;从而…

Express教程【002】:Express监听GET和POST请求

文章目录 2、监听post和get请求2.1 监听GET请求2.2 监听POST请求 2、监听post和get请求 创建02-app.js文件。 2.1 监听GET请求 1️⃣通过app.get()方法&#xff0c;可以监听客户端的GET请求&#xff0c;具体的语法格式如下&#xff1a; // 1、导入express const express req…

ESP32-C3 Vscode+ESP-IDF开发环境搭建 保姆级教程

1.背景 最近esp32的芯片很火&#xff0c;因为芯片自带了WIFI和BLE功能&#xff0c;是物联网项目开发的首选芯片&#xff0c;所以&#xff0c;我也想搞个简单的esp32芯片试试看。于是&#xff0c;我设计了一个简单的板子。如下 这块板子很简单&#xff0c;主要的电路来自于乐鑫…

深入 RAG(检索增强生成)系统架构:如何构建一个能查资料的大语言模型系统

&#x1f407;明明跟你说过&#xff1a;个人主页 &#x1f3c5;个人专栏&#xff1a;《深度探秘&#xff1a;AI界的007》 &#x1f3c5; &#x1f516;行路有良友&#xff0c;便是天堂&#x1f516; 目录 一、前言 1、LLM 的局限&#xff1a;模型知识“封闭” vs 现实知识…

VSCode+Cline 安装配置及使用说明

安装配置 打开VSCode&#xff0c;点击左侧Extension图标&#xff0c;在弹出页面中&#xff0c;检索Cline&#xff0c;选择Cline进行安装。 安装完毕&#xff0c;在左侧会出现一个图标&#xff0c;点击图标 选择【Use your own API key】&#xff0c;在出来的界面中选择大模型&…

【征求意见】四川省大数据发展研究会关于对《数据资源建设费用测算标准》团体标准征求意见的通知

四川省大数据发展研究会 关于对《数据资源建设费用测算标准》团体标准征求意见的通知 各有关单位&#xff1a; 由四川省大数据发展研究会归口、成都东契奇科技有限公司牵头编制的《数据资源建设费用测算标准》团体标准已形成征求意见稿&#xff0c;现公开征求意见。请于2025年…

下载即转化的商业密码:解析华为应用商店CPD广告的智能投放逻辑

在移动互联网流量红利见顶的背景下&#xff0c;华为应用市场凭借其终端生态优势正成为开发者获客的新蓝海。数据显示&#xff0c;2025年Q1华为应用商店全球分发量同比增长27%&#xff0c;其中CPD广告因其"下载才付费"的精准特性&#xff0c;已成为金融、游戏、工具类…

Electron-vite【实战】MD 编辑器 -- 文件列表(含右键快捷菜单,重命名文件,删除本地文件,打开本地目录等)

最终效果 页面 src/renderer/src/App.vue <div class"dirPanel"><div class"panelTitle">文件列表</div><div class"searchFileBox"><Icon class"searchFileInputIcon" icon"material-symbols-light:…

【数据库】并发控制

并发控制 在数据库系统&#xff0c;经常需要多个用户同时使用。同一时间并发的事务可达数百个&#xff0c;这就是并发引入的必要性。 常见的并发系统有三种&#xff1a; 串行事务执行&#xff08;X&#xff09;&#xff0c;每个时刻只有一个事务运行&#xff0c;不能充分利用…

Golang持续集成与自动化测试和部署

概述 Golang是一门性能优异的静态类型语言&#xff0c;但因其奇快的编译速度&#xff0c;结合DevOps, 使得它也非常适合快速开发和迭代。 本文讲述如何使用Golang, 进行持续集成与自动化测试和部署。主要使用了以下相关技术&#xff1a; dep&#xff1a; 进行包的依赖管理gin…

Google car key:安全、便捷的汽车解锁新选择

有了兼容的汽车和 Android 手机&#xff0c;Google car key可让您将Android 手机用作车钥匙。您可以通过兼容的 Android 手机锁定、解锁、启动汽车并执行更多功能。但是&#xff0c;Google car key安全吗&#xff1f;它是如何工作的&#xff1f;如果我的手机电池没电了怎么办&a…

QT开发技术【QTableView分页实现】

一、引言 在开发桌面应用程序时&#xff0c;当需要展示大量数据到表格中&#xff0c;一次性加载所有数据可能会导致界面卡顿、响应缓慢&#xff0c;甚至内存溢出。QTableView 是 Qt 框架中用于展示表格数据的强大组件&#xff0c;结合 QAbstractTableModel 可以实现数据的分页…

新增Vulkan支持|UWA Gears V1.1.0

UWA Gears 是UWA最新发布的无SDK性能分析工具。针对移动平台&#xff0c;提供了实时监测和截帧分析功能&#xff0c;帮助您精准定位性能热点&#xff0c;提升应用的整体表现。 本次版本更新主要是Frame Capture模式新增对Vulkan项目的支持&#xff0c;进一步满足使用Vulkan开发…

mapbox高阶,PMTiles介绍,MBTiles、PMTiles对比,加载PMTiles文件

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:mapbox 从入门到精通 文章目录 一、🍀前言1.1 ☘️mapboxgl.Map 地图对象1.2 ☘️mapboxgl.Map style属性1.3 ☘️Fill面图层样式1.4 ☘️PMTiles介绍1.5…

Sums of Sliding Window Maximum_abc407F分析与解答

倒着考虑&#xff0c;考虑每个a_i对哪些k值做出贡献&#xff0c;对一个a_i&#xff0c;定义L_i和R_i为&#xff1a; 以上笔误&#xff1a;R_i的定义应该是&#xff1a;连续最多R_i个元素比a_i 小 如果得到了 L_i和R_i&#xff0c;我们从k的长度从小到大依次看看&#xff0c;a_…