当前位置:网站首页>一篇让理解你Mysql存储引擎
一篇让理解你Mysql存储引擎
2022-07-21 17:16:00 【学无止境java】
MySQL体系结构
连接层
最上层是一些客户端和链接服务,主要完成一些类似于连接处理、授权认证、及相关的安全方案。服务器也会为安全接入的每个客户
端验证它所具有的操作权限。
服务层
第二层架构主要完成大多数的核心服务功能,如SQL接口,并完成缓存的查询,SQL的分析和优化,部分内置函数的执行。所有跨存
储引擎的功能也在这一层实现,如 过程、函数等。
引擎层
存储引擎真正的负责了MySQL中数据的存储和提取,服务器通过API和存储引擎进行通信。不同的存储引擎具有不同的功能,这样我
们可以根据自己的需要,来选取合适的存储引擎。
存储层
主要是将数据存储在文件系统之上,并完成与存储引擎的交互。
存储引擎简介
存储引擎就是存储数据、建立索引、更新/查询数据等技术的实现方式 。存储引擎是基于表的,而不是基于库的,所以存储引擎也可被
称为表类型。
- 在创建表时,指定存储引擎
- 查看当前数据库支持的存储引擎
SHOW ENGINES;
存储引擎特点
InnoDB
* 介绍
InnoDB是一种兼顾高可靠性和高性能的通用存储引擎,在 MySQL 5.5 之后,InnoDB是默认的 MySQL 存储引擎。
* 特点
DML操作遵循ACID模型,支持事务 ;
行级锁 ,提高并发访问性能;
支持外键 FOREIGN KEY约束,保证数据的完整性和正确性;
* 文件
xxx.ibd:xxx代表的是表名,innoDB引擎的每张表都会对应这样一个表空间文件,存储该表的表结构(frm、sdi)、数据和索引。
参数:innodb_file_per_table
InnoDB
MyISAM
* 介绍
MyISAM是MySQL早期的默认存储引擎。
* 特点
不支持事务,不支持外键
支持表锁,不支持行锁
访问速度快
* 文件
xxx.sdi:存储表结构信息
xxx.MYD: 存储数据
xxx.MYI: 存储索引
Memory
* 介绍
Memory引擎的表数据时存储在内存中的,由于受到硬件问题、或断电问题的影响,只能将这些表作为临时表或缓存使用。
* 特点
内存存放
hash索引(默认)
* 文件
xxx.sdi:存储表结构信息
区别
存储引擎选择
在选择存储引擎时,应该根据应用系统的特点选择合适的存储引擎。对于复杂的应用系统,还可以根据实际情况选择多种存储引擎进行组
合。
* InnoDB : 是Mysql的默认存储引擎,支持事务、外键。如果应用对事务的完整性有比较高的要求,在并发条件下要求数据的一致性,数据操作除了插入和查询之外,还包含很多的更新、删除操作,那么InnoDB存储引擎是比较合适的选择。
* MyISAM : 如果应用是以读操作和插入操作为主,只有很少的更新和删除操作,并且对事务的完整性、并发性要求不是很高,那么选择这个存储引擎是非常合适的。
* MEMORY:将所有数据保存在内存中,访问速度快,通常用于临时表及缓存。MEMORY的缺陷就是对表的大小有限制,太大的表无法缓存在内存中,而且无法保障数据的安全性。
边栏推荐
- Linear table * sequential table (7000 words detailed explanation)
- Shell exercise: Statistics of word frequency
- 量化交易日记-2021年01月总结
- RPA是什么?推荐让电商运营10倍提效的自动化工具
- Try catch finally contains several cases of return and the return result
- js 对象深拷贝
- Partage de la stratégie de percée ultime des commerçants professionnels pendant de nombreuses années (avec un ensemble complet de modèles de transaction)
- Verilog -- Serial four bit adder and leading four bit adder 74hc283
- Alibaba cloud technology expert haochendong: cloud observability - problem discovery and positioning practice
- 基礎不牢地動山搖之牛客刷題《二》
猜你喜欢
阿里云技术专家郝晨栋:云上可观测能力——问题的发现与定位实践
In quantitative trading, it is judged by the moving average system that the upward (downward) momentum is weakened
函数栈帧的形成和销毁(26张图助你深入理解函数栈帧)
One question per day (1)
一个交易系统需要经过几年的考验才算成功的交易系统,盈利需要几年才算稳定?
Self study golang [Chapter 3: the first go language program] use GoLand to create the first go program, the main function and init function, and use go to run Windows commands and realize the data out
Quantitative transaction journal - fallback analysis - February 6, 2021
Quantitative transaction Diary - summary in February 2021
Quantify three types of market in trading
软考中级【数据库系统工程师】第2章:程序语言基础知识,自学软考笔记,程序语言概述程序语言翻译基础低级语言和高级语言编译和解释的区别中缀、前缀与后缀表达式程序语言的数据成分1)常量和变量2)全局变量和局
随机推荐
scrollIntoView
Postman 配置全局变量 postman设置全局token
RunTime+compiler和RunTime only版本的区别
Quantitative transaction journal - fallback analysis - February 6, 2021
指针的深度解刨《五》
Verilog -- 74hc194 multifunctional bidirectional shift register
Self study golang [3.6 slice practice code] slice length, upper limit, copy, delete and increase
Update the version number and static resources (the storage address of the embedded web page)
Location Cache 模块浅析及 OCP 监控、报警详解
Calculation of storage capacity and address space
How does pytorch convert a variable or tensor to numpy?
量化交易中的三类行情
Quantify three types of market in trading
解决IDEA的插件中心连接不上网络
Ffmpeg audio decoding (seconds understand)
线性表*顺序表篇(7000字细致入微讲解)
"Everest" architecture strongly enables the third-generation Roewe rx5/ super hybrid erx5 to refresh the "ceiling" of product power
How does idea import automatically
胜率高达93.98%的TPS交易策略
银河证券vip低佣金开户安全吗?是骗局吗?