MySQL存储引擎

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 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




相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
存储 缓存 关系型数据库
【MySQL进阶篇】存储引擎(MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案)
MySQL的存储引擎是其核心组件之一,负责数据的存储、索引和检索。不同的存储引擎具有不同的功能和特性,可以根据业务需求 选择合适的引擎。本文详细介绍了MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案。
【MySQL进阶篇】存储引擎(MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案)
|
1月前
|
存储 关系型数据库 MySQL
MySQL存储引擎详述:InnoDB为何胜出?
MySQL 是最流行的开源关系型数据库之一,其存储引擎设计是其高效灵活的关键。InnoDB 作为默认存储引擎,支持事务、行级锁和外键约束,适用于高并发读写和数据完整性要求高的场景;而 MyISAM 不支持事务,适合读密集且对事务要求不高的应用。根据不同需求选择合适的存储引擎至关重要,官方推荐大多数场景使用 InnoDB。
75 7
|
3月前
|
存储 SQL 关系型数据库
MySQL存储引擎
本文介绍了数据库优化的多个方面,包括选择合适的存储引擎、字段定义原则、避免使用外键和触发器、大文件存储策略、表拆分及字段冗余处理等。强调了从业务层面进行优化的重要性,如通过活动设计减少外部接口调用,以及在高并发场景下的流量控制与预处理措施。文章还提供了具体的SQL优化技巧和表结构优化建议,旨在提高数据库性能和可维护性。
124 1
MySQL存储引擎
|
2月前
|
存储 缓存 关系型数据库
【赵渝强老师】MySQL的MyISAM存储引擎
在MySQL5.1版本之前,默认存储引擎为MyISAM。MyISAM管理非事务表,提供高速存储和检索,支持全文搜索。其特点包括不支持事务、表级锁定、读写互阻、仅缓存索引等。适用于读多、写少且对一致性要求不高的场景。示例代码展示了MyISAM存储引擎的基本操作。
|
2月前
|
存储 Oracle 关系型数据库
【赵渝强老师】MySQL的InnoDB存储引擎
InnoDB是MySQL的默认存储引擎,广泛应用于互联网公司。它支持事务、行级锁、外键和高效处理大量数据。InnoDB的主要特性包括解决不可重复读和幻读问题、高并发度、B+树索引等。其存储结构分为逻辑和物理两部分,内存结构类似Oracle的SGA和PGA,线程结构包括主线程、I/O线程和其他辅助线程。
【赵渝强老师】MySQL的InnoDB存储引擎
|
2月前
|
存储 关系型数据库 MySQL
【赵渝强老师】MySQL的Memory存储引擎
MySQL 的存储引擎层负责数据的存储和提取,支持多种存储引擎,如 InnoDB、MyISAM 和 Memory。InnoDB 是最常用的存储引擎,从 MySQL 5.5.5 版本起成为默认引擎。Memory 存储引擎的数据仅存在于内存中,重启后数据会丢失。示例中创建了使用 Memory 引擎的 test3 表,并展示了数据在重启后消失的过程。
|
3月前
|
存储 SQL 缓存
MySQL存储引擎如何完成一条更新语句的执行!
MySQL存储引擎如何完成一条更新语句的执行!
MySQL存储引擎如何完成一条更新语句的执行!
|
4月前
|
存储 缓存 关系型数据库
MySQL高级篇——存储引擎和索引
MyISAM:不支持外键和事务,表锁不适合高并发,只缓存索引,内存要求低,查询快MyISAM提供了大量的特性,包括全文索引、压缩、空间函数(GIS)等,但MyISAM不支持事务、行级锁、外键,有一个毫无疑问的缺陷就是崩溃后无法安全恢复。5.5之前默认的存储引擎优势是访问的速度快,对事务完整性没有要求或者以SELECT、INSERT为主的应用针对数据统计有额外的常数存储。故而 count(*) 的查询效率很高表名.frm 存储表结构;表名.MYD 存储数据 (MYData);
MySQL高级篇——存储引擎和索引
|
5月前
|
存储 关系型数据库 MySQL
MySQL 中的事务存储引擎深入解析
【8月更文挑战第31天】
82 0
|
7月前
|
存储 关系型数据库 MySQL

热门文章

最新文章