当前位置:网站首页>Mysql_14 存储引擎
Mysql_14 存储引擎
2022-08-05 00:01:00 【萨科塔资深干员】
存储引擎
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,因为数据索引都存在内存里了。

三种存储引擎的选择

边栏推荐
- Metasploit-域名上线隐藏IP
- Huggingface入门篇 II (QA)
- KT6368A蓝牙的认证问题_FCC和BQB_CE_KC认证或者其它说明
- 基于Appian低代码平台开发一个SpaceX网站
- KT148A voice chip ic working principle and internal architecture description of the chip
- Vscode连接远程服务器(一套配置成功)
- 从单体架构迁移到 CQRS 后,我觉得 DDD 并不可怕
- Handwritten Distributed Configuration Center (1)
- 数据类型及输入输出初探(C语言)
- Security software Avast and Symantec NortonLifeLock merge with UK approval, market value soars 43%
猜你喜欢

【论文笔记】—低照度图像增强—Unsupervised—EnlightenGAN—2019-TIP

Xiaohei leetcode surfing: 94. Inorder traversal of binary tree
手写分布式配置中心(1)

Pytorch分布式训练/多卡/多GPU训练DDP的torch.distributed.launch和torchrun

论文解读( AF-GCL)《Augmentation-Free Graph Contrastive Learning with Performance Guarantee》

软件开发工具的技术要素

VMware NSX 4.0 -- 网络安全虚拟化平台

【LeetCode】滑动窗口题解汇总

Xiaohei's leetcode journey: 95. Longest substring with at least K repeating characters

First, the basic concept of reptiles
随机推荐
d枚举生成位
STC89C52RC的P4口的应用问题
#yyds dry goods inventory #Switching equipment serious packet loss troubleshooting
[Cloud Native--Kubernetes] Pod Controller
@Import注解的作用以及如何使用
上课笔记(6)(2)——#742. 周末舞会
2022牛客暑期多校训练营5(BCDFGHK)
导入JankStats检测卡帧库遇到问题记录
Day118. Shangyitong: order list, details, payment
如何写好测试用例
OpenCV:10特征检测
LeetCode Hot 100
招标公告 | 海纳百创公众号运维项目
英特尔WiFi 7产品将于2024年亮相 最高速度可达5.8Gbps
【LeetCode】双指针题解汇总
三、实战---爬取百度指定词条所对应的结果页面(一个简单的页面采集器)
网站最终产品页使用单一入口还是多入口?
情侣牵手[贪心 & 抽象]
对写作的一些感悟
10 种常见的BUG分类