Mysql_14 存储引擎

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: b站黑马网课

存储引擎

Mysql 体系结构

在这里插入图片描述

连接层:连接池部分,与客户端连接,并检查授权认证、权限、最大连接数等。

服务层:SQL接口一行,绝大部分核心功能如SQL解析优化、所有跨存储引擎的实现都在这一层。

引擎层:可插拔存储引擎一行,索引在这一层实现,决定数据库数据如何存、取、组织。如果当前引擎不满足需求还可以拓展,因此被称作可插拔。

存储层:最下面一行,存取数据库的相关数据。

存储引擎简介

存储数据、建立索引、更新/查询数据等技术的实现方式。存储引擎是基于表的,而不是基于库的。

查询建表语句:show create table 表名;时在结尾就可以看到该表的存储引擎。

show engines;查询当前数据库支持的所有引擎。

创建指定引擎的表:create table (...) engine=指定引擎;

修改表引擎:alter table 表名 engine=指定引擎;

InnoDB

高性能存储引擎,Mysql 5.5后的默认引擎。

支持事务、行级锁、外键。

文件后缀.ibd是InnoDB存储引擎的表空间文件,每个表有一个,存储表结构数据和索引。表结构早期是frm,后来变成sdi,sdi又融入了ibd格式中。

有一个系统变量innodb_file_per_table,可以通过show variables like 'innodb_file_per_table'查看,ON则表示每张表都对应一个表空间文件ibd。

ibd文件在mysql文件夹-data文件夹-对应数据库文件夹里。

ibd文件直接打开是看不了的,都是二进制。可以进入目标文件夹后,通过命令行ibd2sdi 指定表名.ibd,就可以查看该表的json文件信息了。

在这里插入图片描述

表空间文件逻辑存储结构如图所示,段-区-页-行,每一行就是表中的一行数据。

一个区大小固定为1M,一页大小固定为16K。(大概了解,SQL优化部分还要涉及)

MYISAM

数据库早期的默认存储引擎。(现在功能几乎可以被NoSQL的Mongodb取代)

不支持事务和外键,支持表锁,不支持行锁,访问速度快。

存储文件包括:

.MYD:数据

.MYI:索引

.sdi:表结构,可以直接打开,里面装的是json格式内容(可以通过json.cn格式化)。

Memory

存放在内存中,数据是临时的。(现在功能几乎可以被NoSQL的Redis取代)

访问速度快,支持hash索引。

存储文件只包括:.sdi,因为数据索引都存在内存里了。

在这里插入图片描述

三种存储引擎的选择

在这里插入图片描述

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
4月前
|
存储 缓存 关系型数据库
MySQL 存储引擎
MySQL 存储引擎
58 6
|
4月前
|
存储 缓存 关系型数据库
MySQL两种存储引擎及区别
MySQL两种存储引擎及区别
61 4
MySQL两种存储引擎及区别
|
11天前
|
存储 关系型数据库 MySQL
MySQL 中的事务存储引擎深入解析
【8月更文挑战第31天】
11 0
|
3月前
|
存储 关系型数据库 MySQL
|
2月前
|
存储 关系型数据库 MySQL
MySQL InnoDB存储引擎的优点有哪些?
上述提到的特性和优势使得InnoDB引擎非常适合那些要求高可靠性、高性能和事务支持的场景。在使用MySQL进行数据管理时,InnoDB通常是优先考虑的存储引擎选项。
63 0
|
3月前
|
存储 关系型数据库 MySQL
MySQL数据库进阶第一篇(存储引擎与Linux系统上安装MySQL数据库)
MySQL数据库进阶第一篇(存储引擎与Linux系统上安装MySQL数据库)
|
3月前
|
存储 算法 关系型数据库
【MySQL技术内幕】5.7- InnoDB存储引擎中的哈希算法
【MySQL技术内幕】5.7- InnoDB存储引擎中的哈希算法
33 1
|
3月前
|
存储 SQL 关系型数据库
MYSQL--(1.存储引擎 *2.事务*)
MYSQL--(1.存储引擎 *2.事务*)
|
3月前
|
存储 关系型数据库 MySQL
【MySQL技术内幕】1-MySQL体系结构和存储引擎
【MySQL技术内幕】1-MySQL体系结构和存储引擎
32 1
|
2月前
|
存储 关系型数据库 MySQL
MySQL存储引擎
MySQL存储引擎
27 0

热门文章

最新文章