存储引擎说白了就是如何存储数据、如何为存储的数据建立索引和如何更新、查询数据等技术的实现方法。因为在关系数据库中数据的存储是以表的形式存储的,所以存储引擎也可以称为表类型(即存储和操作此表的类型)。
在Oracle 和SQL Server等数据库中只有一种存储引擎,所有数据存储管理机制都是一样的。而MySql数据库提供了多种存储引擎。用户可以根据不同的需求为数据表选择不同的存储引擎,用户也可以根据自己的需要编写自己的存储引擎。
1、MySql中有哪些存储引擎?MyISAM:这种引擎是mysql最早提供的。这种引擎又可以分为静态MyISAM、动态MyISAM 和压缩MyISAM三种,不管是何种MyISAM表,目前它都不支持事务,行级锁和外键约束的功能。
MyISAM Merge引擎:这种类型是MyISAM类型的一种变种。合并表是将几个相同的MyISAM表合并为一个虚表。常应用于日志和数据仓库。
InnoDB:InnoDB表类型可以看作是对MyISAM的进一步更新产品,它提供了事务、行级锁机制和外键约束的功能,也是目前MySQL默认的存储引擎。
Memory(heap):这种类型的数据表只存在于内存中。它使用散列索引,所以数据的存取速度非常快。因为是存在于内存中,所以这种类型常应用于临时表中。
archive:这种类型只支持select 和 insert语句,而且不支持索引。常应用于日志记录和聚合分析方面。
当然MySql支持的表类型不止上面几种。下面我们介绍一下如何查看和设置数据表类型。
2、存储引擎的操作
查看数据库可以支持的存储引擎,用show engines; 命令可以显示当前数据库支持的存储引擎情况:
-- 查询 MySQL 支持的存储引擎SHOW ENGINES\G;-- 查询结果(省略的结果)***************************[ 2. row ]***************************Engine | MEMORYSupport | YESComment | Hash based, stored in memory, useful for temporary tablesTransactions | NOXA | NOSavepoints | NO***************************[ 5. row ]***************************Engine | MyISAMSupport | YESComment | MyISAM storage engineTransactions | NOXA | NOSavepoints | NO........
MySQL 从5.0 开始默认的存储引擎是 InnoDB,这一点可以通过系统变量 default_storage_engine 查询到系统默认的存储引擎。
mysql root@localhost:sakila> show variables like 'default_storage_engine';+------------------------+--------+| Variable_name | Value |+------------------------+--------+| default_storage_engine | InnoDB |+------------------------+--------+
存储引擎是基于表的,因此可以在创建的时候指定存储引擎。
-- 创建表的时候指定存储引擎,默认是 InnoDBCREATE TABLE test_table(id int primary key auto_increment,name varchar(128) NOT NULL)ENGINE = MyISAM;
3、各个存储引擎的特征
不同的存储引擎有着不同的特征,有的支持事务,有的不支持事务,因此这里需要读者熟悉常用的存储引擎 InnoDB和MyISAM的区别。