Mysql的数据库存储引擎
数据库的存储引擎是数据库底层软件组织,数据库管理系统(DBMS)使用数据引擎进行创建、查询、更新和删除数据。不同的存储引擎提供不同的存储机制、索引技巧、锁定水平等功能,使用不同的存储引擎,还可以 获得特定的功能。MySQL的核心就是存储引擎。最知名的是InnoDB和MyISAM。
1.存储引擎的查看
查看数据库可配置的存储引擎: show engines;
查看数据库正在使用的存储引擎:
show table status from 库 where name='表1'; #查看表1正在使用的存储引擎
2.存储引擎的配置
通过命令修改
use 库; #进入数据库
alter table 表1 engine=MyISAM; #修改存储引擎为MyISAM
alter table 表2 engine=InnoDB; #修改存储引擎为InnoDB
创建表时指定存储引擎
use 库; #进入库
create table 表1(id int)engine=InnoDB; #修改存储引擎为InnoDB
create table 表2(id int)engine=MyISAM; #修改存储引擎为MyISAM
show create table 表; #查看
通过配置文件修改,仅对之后新建的表有效
vim /etc/my.cnf
...
...
[mysqld]
default--storage-engine=MyISAM //添加你要设为默认的存储引擎
我这里使用的是MySQL5.7,通过查看可知
YES表示可以使用、NO表示不能使用、DEFAULT表示该引擎为当前默认的存储引擎 。下面来看一下其中几种常用的引擎。
InnoDB存储引擎
InnoDB是事务型数据库的首选引擎,还是mysql默认的引擎。InnoDB给Mysql的表提供了事务、回滚、崩溃修复能力、多版本并发控制的事务安全、间隙锁(可以有效的防止幻读的出现)、支持辅助索引、聚簇索引、自适应hash索引、支持热备、行级锁。还有InnoDB是Mysql上唯一一个提供了外键约束的引擎。其主要特征有:
1)InnoDB给MySQL提供了具有提交、回滚和崩溃恢复能力的事物安全(ACID兼容)存储引擎。InnoDB锁定在行级并且也在SELECT语句中提供一个类似Oracle的非锁定读。这些功能增加了多用户部署和性能。在SQL查询中,可以自由地将InnoDB类型的表和其他MySQL的表类型混合起来,甚至在同一个查询中也可以混合。
2)InnoDB是为处理巨大数据量的最大性能设计。它的CPU效率可能是任何其他基于磁盘的关系型数据库引擎锁不能匹敌的。
3)InnoDB存储引擎完全与MySQL服务器整合,InnoDB存储引擎为在主内存中缓存数据和索引而维持它自己的缓冲池。InnoDB将它的表和索引在一个逻辑表空间中,表空间可以包含数个文件(或原始磁盘文件)。这与MyISAM表不同,比如在MyISAM表中每个表被存放在分离的文件中。InnoDB表可以是任何尺寸,即使在文件尺寸被限制为2GB的操作系统上。
4)InnoDB支持外键完整性约束,存储表中的数据时,每张表的存储都按主键顺序存放,如果没有显示在表定义时指定主键,InnoDB会为每一行生成一个6字节的ROWID,并以此作为主键。
5)InnoDB被用在众多需要高性能的大型数据库站点上。
6)1.InnoDB不支持FULLTEXT(全文索引)类型的索引。
InnoDB不创建目录,使用InnoDB时,MySQL将在MySQL数据目录下创建一个名为ibdata1的10MB大小的自动扩展数据文件,以及两个名为ib_logfile0和ib_logfile1的5MB大小的日志文件。
MyISAM存储引擎
MyISAM基于ISAM存储引擎,并对其进行扩展。MyISAM支持全文索引、压缩存放、空间索引(空间函数)、表级锁、延迟更新索引键。但是MyISAM不支持事务、行级锁、更无法忍受的是崩溃后不能保证完全恢复(只能手动修复)。
MyISAM存储引擎的插入数据很快,空间和内存使用比较低。如果表主要是用于插入新记录和读出记录,那么选择MyISAM存储引擎能够实现处理的高效率。如果应用的完整性、并发性要求很低,也可以选择MyISAM存储引擎。
MyISAM的特征:
1)可以把数据文件和索引文件放在不同目录。
2)表级锁定形式,数据在更新时锁定整个表。
3)数据库读写过程中相互阻塞。
4)可以通过key_buffer_size来设置缓存索引。
5)数据单独写入或读取速度快占用资源少。
6)不支持外键约束,只支持全文索引。
7)建表时会生成三个文件,文件名均以表的名字开始。
显而易见MyISAM的适用于非事务型应用,只读类应用,空间类应用。
不同的引擎在保存表的结构和数据时采用不同的方式
MyISAM表文件含义:.frm表定义,.MYD表数据,.MYI表索引
InnoDB表文件含义:.frm表定义,表空间数据和日志文件
SHOW ENGINES -- 显示存储引擎的状态信息
SHOW ENGINE 引擎名 {LOGS|STATUS} -- 显示存储引擎的日志或状态信息
InnoDB和MyISAM的主要区别:
1. MyISAM 不支持事务处理等高级处理,强调的是性能,其执行速度比 InnoDB 更快,但是不提供事务支持,而 InnoDB 提供事务支持、外部键等高级数据库功能。
2.MyISAM的索引和数据是分开的,并且索引是有压缩的,内存使用率就对应提高了不少。能加载更多索引,而Innodb的索引和数据是紧密捆绑的,没有使用压缩从而会造成Innodb比MyISAM体积庞大。
Memory存储引擎
MEMORY存储引擎是Mysql中的一类特殊的存储引擎。其使用存储在内存中的内存来创建表,而且所有数据保存在内存中。数据安全性很低,但是查找和插入速度很快。如果内存出现异常就会影响到数据的完整性,如果重启或关机,表中的所有数据就会丢失,因此基于MEMORY存储引擎的表的生命周期很短,一般都是一次性的。适用于某些特殊场景像查找和映射,缓存周期性的聚合数据等等。
Blackhome存储引擎
Blackhome叫做黑洞,也就是说没有存储机制,任何数据都会被丢弃,但是会记录二进制日志。一般在Mysql复制(中继服务器)中经常用到。
CSV存储引擎
CSV是将数据文件保存为CSV格式的的文件的,可以方便的导入到其他数据库中去(如:excel表格,SQLserver等等),需要在数据库间自由共享数据时才偶尔建议使用此存储引擎。并且它也不支持索引。
简单介绍到此。。。如有不足,欢迎留言指正。望不吝赐教。。。