【MySQL】存储引擎

存储引擎

  • 查看存储引擎
  • 设置表的存储引擎
  • 引擎介绍
    • [InnoDB引擎: 具备外键支持的十五存储引擎](#InnoDB引擎: 具备外键支持的十五存储引擎)
    • [MyISAM引擎: 主要的非事务处理存储引擎](#MyISAM引擎: 主要的非事务处理存储引擎)
    • [Archive引擎: 用于数据存档](#Archive引擎: 用于数据存档)
    • [Blackhole引擎: 丢弃写操作,读操作返回空内容](#Blackhole引擎: 丢弃写操作,读操作返回空内容)
    • [CSV引擎: 读取数据时,以逗号分隔各个数据项](#CSV引擎: 读取数据时,以逗号分隔各个数据项)
    • [Menory引擎: 置于内存的表](#Menory引擎: 置于内存的表)
  • MyISMA和InnoDB

查看存储引擎

sql 复制代码
show engines

设置表的存储引擎

创建表时指定存储引擎

sql 复制代码
create table 表名(
	建表语句
)engin = 存储引擎名称;

修改表的存储引擎

sql 复制代码
alter table 表名 engin = 存储引擎名称;

引擎介绍

InnoDB引擎: 具备外键支持的十五存储引擎

  1. InnoDB是MySQL的 默认事务型引擎 ,它被设计用来处理大量的短期(short-lived)事务。可以确保事务的完整提交(Commit)和回滚(Rollback)。
  2. 数据文件结构: 表名.frm存储表结构,表名.ibd存储数据和索引
  3. 对比MyISAM的存储引擎, InnoDB写的处理效率差一些 ,并且会占用更多的磁盘空间以保存数据和索引。
  4. MyISAM只缓存索引,不缓存真实数据;InnoDB不仅缓存索引还要缓存真实数据, 对内存要求较高 ,而且内存大小对性能有决定性的影响。

MyISAM引擎: 主要的非事务处理存储引擎

  1. MyISAM提供了大量的特性,包括全文索引、压缩、空间函数(GIS)等,但MyISAM 不支持事务、行级锁、外键 ,有一个毫无疑问的缺陷就是 崩溃后无法安全恢复 。
  2. 优势是访问的 速度快 ,对事务完整性没有要求或者以SELECT、INSERT为主的应用
  3. 针对数据统计有额外的常数存储。故而 count(*) 的查询效率很高
  4. 数据文件结构:表名.frm存储表结构,表名.MYD存储数据,表名.MYI存储索引

Archive引擎: 用于数据存档

Blackhole引擎: 丢弃写操作,读操作返回空内容

CSV引擎: 读取数据时,以逗号分隔各个数据项

创建CSV表还会创建相应的 元文件 ,用于 存储表的状态 和 表中存在的行数 。此文件的名称与表的名称相同,后缀为 CSM 。
如果检查 test.CSV 通过执行上述语句创建的数据库目录中的文件,这种格式可以被 Microsoft Excel 等电子表格应用程序读取,甚至写入。

Menory引擎: 置于内存的表

Memory采用的逻辑介质是 内存 , 响应速度很快 ,但是当mysqld守护进程崩溃的时候 数据会丢失 。另外,要求存储的数据是数据长度不变的格式,比如,Blob和Text类型的数据不可用(长度不固定的)。

主要特征

  1. Memory同时 支持哈希(HASH)索引 和 B+树索引 。
  2. Memory表至少比MyISAM表要 快一个数量级 。
  3. MEMORY 表的大小是受到限制 的。表的大小主要取决于两个参数,分别是 max_rows 和max_heap_table_size 。其中,max_rows可以在创建表时指定;max_heap_table_size的大小默认为16MB,可以按需要进行扩大。
  4. 数据文件与索引文件分开存储。
  5. 缺点:其数据易丢失,生命周期短。基于这个缺陷,选择MEMORY存储引擎时需要特别小心。

MyISMA和InnoDB

相关推荐
技术宝哥1 小时前
Redis(2):Redis + Lua为什么可以实现原子性
数据库·redis·lua
学地理的小胖砸2 小时前
【Python 操作 MySQL 数据库】
数据库·python·mysql
dddaidai1233 小时前
Redis解析
数据库·redis·缓存
数据库幼崽3 小时前
MySQL 8.0 OCP 1Z0-908 121-130题
数据库·mysql·ocp
Amctwd3 小时前
【SQL】如何在 SQL 中统计结构化字符串的特征频率
数据库·sql
betazhou3 小时前
基于Linux环境实现Oracle goldengate远程抽取MySQL同步数据到MySQL
linux·数据库·mysql·oracle·ogg
lyrhhhhhhhh4 小时前
Spring 框架 JDBC 模板技术详解
java·数据库·spring
喝醉的小喵5 小时前
【mysql】并发 Insert 的死锁问题 第二弹
数据库·后端·mysql·死锁
付出不多6 小时前
Linux——mysql主从复制与读写分离
数据库·mysql
初次见面我叫泰隆6 小时前
MySQL——1、数据库基础
数据库·adb