存储引擎说白了就是如何存储数据、如何为存储的数据建立索引和如何更新、查询数据等技术的实现方法。因为在关系数据库中数据的存储是以表的形式存储的,所以存储引擎也可以称为表类型(即存储和操作此表的类型)。
在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 | MEMORY
Support | YES
Comment | Hash based, stored in memory, useful for temporary tables
Transactions | NO
XA | NO
Savepoints | NO
***************************[ 5. row ]***************************
Engine | MyISAM
Support | YES
Comment | MyISAM storage engine
Transactions | NO
XA | NO
Savepoints | 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 |
+------------------------+--------+
存储引擎是基于表的,因此可以在创建的时候指定存储引擎。
-- 创建表的时候指定存储引擎,默认是 InnoDB
CREATE TABLE test_table(
id int primary key auto_increment,
name varchar(128) NOT NULL
)ENGINE = MyISAM;
3、各个存储引擎的特征
不同的存储引擎有着不同的特征,有的支持事务,有的不支持事务,因此这里需要读者熟悉常用的存储引擎 InnoDB和MyISAM的区别。