文档章节

MySQL存储引擎

casoc
 casoc
发布于 2017/08/15 09:36
字数 518
阅读 29
收藏 0

MySQL5.0支持的存储引擎包含MyISAM、InnoDB、BDB、MEMORY、MERGE、EXAMPLE、NDB Cluster、ARCHIVE、CSV、BACKHOLE、FEDERATED等,其中InnoDB和BDB提供事务安全表,其他存储引擎都是非事务安全表。

 

MySQL5.5之前默认存储引擎是MyISAM,之后是InnoDB

MyISAM不支持事务不支持外键,优势是访问速度快,多用于读多余写的情况。

每个MyISAM在磁盘上存储成3个文件,其文件名都和表名相同,扩展名分别是:

  • .frm(存储表定义)
  • .MYD(MYData,存储数据)
  • .MYI(MYIndex,存储索引)

数据文件和索引文件可以放置在不同的目录,平均分布IO。获得更快的速度。

MyISAM类型的表可能会损坏,可以用CHECK TABLE语句来检查表的健康,并用REPAIR TABLE语句修复损坏的表。

MyISAM的表支持3中不用的存储格式:

  • 静态(固定长度)表
  • 动态表
  • 压缩表

静态表是默认存储格式,每条记录长度固定,不能扩容,如果数据长度不够,将用空格补足;

优点:存储非常迅速,容易缓存,出现故障容易恢复;

缺点:占用的空间通常比动态表多,同时获取数据时会自动去除后面的空格,如果数据保存时本来是希望有空格,那这里拿出来的数据将于期望的不同。

动态表,包含变长字段,记录不是固定长度的,优点:占用的空间相对较少,但是频繁的更新和删除记录会产生碎片,需要定期执行OPTIMIZE TABLE语句或myisamchk -r命令来改善性能,并且出现故障时恢复相对比较困难。

压缩表由myisampack工具创建,占据非常小的磁盘空间,因为每个记录都是被单独压缩的,所以只有非常小的访问开支。

查看当前数据库支持的存储引擎:

show engines;

查看表使用的存储引擎:

show table status from <db_name> where name='<table_name>';

© 著作权归作者所有

上一篇: MySQL锁
下一篇: 线程池
casoc
粉丝 48
博文 85
码字总数 60735
作品 0
成都
程序员
私信 提问

暂无文章

java通过ServerSocket与Socket实现通信

首先说一下ServerSocket与Socket. 1.ServerSocket ServerSocket是用来监听客户端Socket连接的类,如果没有连接会一直处于等待状态. ServetSocket有三个构造方法: (1) ServerSocket(int port);...

Blueeeeeee
今天
6
0
用 Sphinx 搭建博客时,如何自定义插件?

之前有不少同学看过我的个人博客(http://python-online.cn),也根据我写的教程完成了自己个人站点的搭建。 点此:使用 Python 30分钟 教你快速搭建一个博客 为防有的同学不清楚 Sphinx ,这...

王炳明
昨天
5
0
黑客之道-40本书籍助你快速入门黑客技术免费下载

场景 黑客是一个中文词语,皆源自英文hacker,随着灰鸽子的出现,灰鸽子成为了很多假借黑客名义控制他人电脑的黑客技术,于是出现了“骇客”与"黑客"分家。2012年电影频道节目中心出品的电影...

badaoliumang
昨天
15
0
很遗憾,没有一篇文章能讲清楚线程的生命周期!

(手机横屏看源码更方便) 注:java源码分析部分如无特殊说明均基于 java8 版本。 简介 大家都知道线程是有生命周期,但是彤哥可以认真负责地告诉你网上几乎没有一篇文章讲得是完全正确的。 ...

彤哥读源码
昨天
15
0
jquery--DOM操作基础

本文转载于:专业的前端网站➭jquery--DOM操作基础 元素的访问 元素属性操作 获取:attr(name);$("#my").attr("src"); 设置:attr(name,value);$("#myImg").attr("src","images/1.jpg"); ......

前端老手
昨天
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部