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

【MySQL】存储引擎 - MEMORY详解

📢博客主页:https://blog.csdn.net/2301_779549673
📢博客仓库:https://gitee.com/JohnKingW/linux_test/tree/master/lesson
📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正!
📢本文由 JohnKi 原创,首发于 CSDN🙉
📢未来很长,值得我们全力奔赴更美好的生活✨

在这里插入图片描述

在这里插入图片描述

文章目录

  • 🏳️‍🌈一、使用场景
  • 🏳️‍🌈二、 MEMORY存储引擎的特性
  • 🏳️‍🌈三、创建MEMORY表
  • 🏳️‍🌈四、内存管理
  • 👥总结


使用 MEMORY 存储引擎(以前称为HEAP)创建的表,内容存储在内存中。当服务器由于硬件问题断电或其他原因崩溃时数据会丢失,因此这些表仅用作 临时工作区从其他表中提取数据的只读缓存

🏳️‍🌈一、使用场景

  • 涉及瞬时、非关键数据的操作,例如会话管理或需要缓存的数据,当服务器停止或重新启动时,MEMORY 表中的数据会丢失:
  • 用于快速访问和低延时,数据量可以完全放在物理内存中,不使用虚拟内存;只读或以读为主的数据访问场景(有限的更新)。

🏳️‍🌈二、 MEMORY存储引擎的特性

在这里插入图片描述

  • 使用固定长度的存储格式,可变长度类型,例如 VARCHAR 使用固定长度存储;
  • 不能包含 BLOBTEXT 列;
  • 支持 AUTO_INCREMENT 的列;
  • TEMPORARY MEMORY 表在所有客户端之间共享;
  • 支持 HASH 索引(默认)和 BTREE 索引;
  • 不支持表分区;
  • 由于使用单线程,在高负载的场景下可能会涉及严重的锁竞争,特别是在多个客户端并发执行更新操作的情况下,性能并不一定会比 InnoDB 更快。

🏳️‍🌈三、创建MEMORY表

在MySQL8.0中 InnoDB 是默认引擎,所以在创建表时需要指定 ENGINE=MEMORY:

# 创建⼀个使⽤MEMORY存储引擎的表
CREATE TABLE t_memory1 (id int(11) PRIMARY KEY AUTO_INCREMENT,name varchar(20)
) ENGINE = MEMORY;

在这里插入图片描述

创建表并加载数据

在这里插入图片描述
启动时填充 MEMORY 表的内容,可以使用 init_file 系统变量指定一个SQL文件,文件中可以编写用于初始化数据的SQL语句,例如: INSERTINTO...SELECTLOAD DATA

🏳️‍🌈四、内存管理

  • 删除单行数据,不会回收内存,只有删除整个表时才会回收内存。当不需要内存表的内容时,要释放该表所使用的所有内存,可以执行 DELETETRUNCATE table 删除所有行,或者使用 DROP table 删除表。如果要释放被删除行所使用的内存,使用 ALTER TABLE ENGINE=MEMORY 命令强制重建表;
  • 表中一行数据所需的内存使用以下表达式计算:
# 涉及到所有BTREE索引⻓度、所有的HASH索引⻓度、单⾏数据⻓度
SUM_OVER_ALL_BTREE_KEYS(max_length_of_key + sizeof(char*) * 4)
+ SUM_OVER_ALL_HASH_KEYS(sizeof(char*) * 2)
+ ALIGN(length_of_row+1, sizeof(char*))

ALIGN()函数的作用:使行长度为char类型大小的精确倍数。sizeof(char*)在32位机器上是4,在64位机器上是8。

  • max_heap_table_size 系统变量设置了内存表的最大大小限制,默认为 16MB,要控制单个表的最大大小,在创建每个表之前设置该变量的 session 值。(不要改变全局的 max_heap_table_size 值,除非要明确设置所有客户端创建的内存表),下面的示例创建了两个内存表,最大大小分别为 1MB2MB:
# 指定第⼀张表的内存最⼤值为1MB
mysql> SET max_heap_table_size = 1024*1024;
Query OK, 0 rows affected (0.00 sec)
mysql> CREATE TABLE t1 (id INT, UNIQUE(id)) ENGINE = MEMORY;
Query OK, 0 rows affected (0.01 sec)# 指定第⼆张表的内存最⼤值为2MB
mysql> SET max_heap_table_size = 1024*1024*2;
Query OK, 0 rows affected (0.00 sec)
mysql> CREATE TABLE t2 (id INT, UNIQUE(id)) ENGINE = MEMORY;
Query OK, 0 rows affected (0.00 sec)

每次重启服务器内存表中的数据将被清空,内存表中的数据永远不会写入磁盘


👥总结

本篇博文对 【MySQL】存储引擎 - MEMORY详解 做了一个较为详细的介绍,不知道对你有没有帮助呢

觉得博主写得还不错的三连支持下吧!会继续努力的~

相关文章:

  • 使用 CDN 在国内加载本地 PDF 文件并处理批注:PDF.js 5.x 实战指南
  • Ubuntu 安装 Nginx
  • 【hadoop】案例:Sqoop迁移仓库数据
  • OpenTelemetry 介绍
  • 【软件推荐——ScreenToGif】
  • docker 部署clickhouse
  • [数据处理] 6. 数据可视化
  • Java 17配置Jenkins
  • 基于Django和Bootstrap开发的美食推荐系统
  • 函数级重构:如何写出高可读性的方法?
  • 探讨关于智能体(Agent)结合 Dify、大语言模型(LLM)以及 Qwen-3 模型的项目或概念
  • VNC windows连接ubuntu桌面
  • Linux——Mysql数据库
  • 安全可控·高效响应|北峰智能互通矿业通信系统解决方案
  • 记录 iframe 跨域通信及安全配置
  • MariaDB 与 MySQL 的关系:从同源到分道扬镳
  • 二叉树的基本操作
  • 浅谈 Shell 脚本编程中引号的妙用
  • Logback官方文档翻译章节目录
  • conda创建一个新环境,指定环境的存储位置,而不是默认值地址
  • 纪念|古文字学泰斗裘锡圭:“还有很多事情要做”
  • 经济日报整版聚焦“妈妈岗”:就业路越走越宽,有温度重实效
  • 深入贯彻中央八项规定精神学习教育中央第一指导组指导督导河北省见面会召开
  • 不主动上门检查,上海已制定14个细分领域“企业白名单”甄别规则
  • 陕西澄城打造“中国樱桃第一县”:从黄土高原走向海外,年产值超30亿
  • 哥伦比亚总统称将在访华期间签署“一带一路”倡议意向书,外交部回应