MySQL存储引擎

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: MySQL存储引擎

一、MySQL体系结构



Mysql底层也有缓存,也有查询优化器,会进行自主优化


image.png


Mysql体系结构


二、存储引擎只针对表,数据库中允许出现不同引擎



• InnoDB • MyISAM
• XtraDB • CSV
• Memory • Archive
• Federated • ...


三、InnoDB存储引擎



1.MySQL 5.5.8后InnoDB是默认存储引擎

2.InnoDB采用”表空间”保存文件

3.InnoDB支持事务处理


四、InnoDB的存储特性



InnoDB表空间有两种形式


  1. 使用系统表空间 ibdataN(不推荐)
    所有数据都在一个表空间中,不利于数据的回收
  2. 独立表空间:tablename.ibd(推荐)
    设置innodb_file_per_table决定表空间模式

五、为什么推荐独立表空间



1.系统表空间 all in one 不利于管理

2.系统表空间会产生IO瓶颈

3.系统表空间很难回收存储空间

4.独立表空间使用optimize table 命令回收存储空间


六、InnoDB的事务特性



1.InnoDB支持事务

2.InnoDB默认使用行级锁

3.InnoDB具备良好的高并发特性


七、InnoDB的适用场景



1.InnoDB存储引擎适用于绝大多数场景

2.MySQL 5.7 以后 InnoDB也支持全文索引与空间函数

3.5.5版本以前默认是MyISAM


八、MyISAM存储引擎


1.不支持事务

2.支持全文检索,支持text支持前缀索引

3.支持数据压缩

4.紧密存储,顺序读性能很好

5.表级锁,混合读写性能不佳,并发性差


九、MyISAM应用场景



1.非事务应用 ,例如: 保存日志

2.只读类应用 ,报表数据,字典数据

3.空间类应用,开发GIS系统(5.7版本以前)

4.系统临时表,SQL查询,分组的临时表引擎


十、Memory存储引擎



1.不支持事务

2.内存读写,临时存储

3.超高的读写效率,比MyISAM高一个量级

4.表级锁,并发性差


十一、Memory应用场景



1.读多写少的静态数据,例如省市县的对应表

2.充当缓存使用,保存高频访问静态数据

3.系统临时表


十二、Memory关键参数



设置max_heap_table_size控制内存表大小(字节)

设置tmp_table_size设置内存临时表最大值(字节)


十三、CSV存储引擎



1.纯文本保存

2.不支持事务

3.不支持索引


十四、CSV应用场景



数据交换/数据迁移


image.png

image.png


不依赖MySQL环境


image.png

image.png




相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
5月前
|
存储 缓存 关系型数据库
MySQL 存储引擎
MySQL 存储引擎
64 6
|
11天前
|
存储 SQL 缓存
MySQL存储引擎如何完成一条更新语句的执行!
MySQL存储引擎如何完成一条更新语句的执行!
MySQL存储引擎如何完成一条更新语句的执行!
|
1月前
|
存储 缓存 关系型数据库
MySQL高级篇——存储引擎和索引
MyISAM:不支持外键和事务,表锁不适合高并发,只缓存索引,内存要求低,查询快MyISAM提供了大量的特性,包括全文索引、压缩、空间函数(GIS)等,但MyISAM不支持事务、行级锁、外键,有一个毫无疑问的缺陷就是崩溃后无法安全恢复。5.5之前默认的存储引擎优势是访问的速度快,对事务完整性没有要求或者以SELECT、INSERT为主的应用针对数据统计有额外的常数存储。故而 count(*) 的查询效率很高表名.frm 存储表结构;表名.MYD 存储数据 (MYData);
MySQL高级篇——存储引擎和索引
|
2月前
|
存储 关系型数据库 MySQL
MySQL 中的事务存储引擎深入解析
【8月更文挑战第31天】
42 0
|
4月前
|
存储 关系型数据库 MySQL
|
3月前
|
存储 关系型数据库 MySQL
MySQL InnoDB存储引擎的优点有哪些?
上述提到的特性和优势使得InnoDB引擎非常适合那些要求高可靠性、高性能和事务支持的场景。在使用MySQL进行数据管理时,InnoDB通常是优先考虑的存储引擎选项。
140 0
|
4月前
|
存储 关系型数据库 MySQL
MySQL数据库进阶第一篇(存储引擎与Linux系统上安装MySQL数据库)
MySQL数据库进阶第一篇(存储引擎与Linux系统上安装MySQL数据库)
|
4月前
|
存储 算法 关系型数据库
【MySQL技术内幕】5.7- InnoDB存储引擎中的哈希算法
【MySQL技术内幕】5.7- InnoDB存储引擎中的哈希算法
47 1
|
4月前
|
存储 SQL 关系型数据库
MYSQL--(1.存储引擎 *2.事务*)
MYSQL--(1.存储引擎 *2.事务*)
|
4月前
|
存储 关系型数据库 MySQL
【MySQL技术内幕】1-MySQL体系结构和存储引擎
【MySQL技术内幕】1-MySQL体系结构和存储引擎
41 1