mysql的存储引擎

     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等等),需要在数据库间自由共享数据时才偶尔建议使用此存储引擎。并且它也不支持索引。

简单介绍到此。。。如有不足,欢迎留言指正。望不吝赐教。。。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值