bitsCN.com
腾讯面试提及
参考来源:http://database.51cto.com/art/201011/234306.htm
MySQL实际上支持五种不同的表类型.这五种类型分别是BDB、HEAP、ISAM、MERGE以及MyISAM。其中BDB类型单独属于一类,称为“事务安全型”(transaction-safe),其余的表类型属于第二类,称为“非事务安全型”(non-transaction-safe)。
1,ISAM数据表
mysql3.23版本之前的MySQL支特的唯一一种表类型,目前己经过时,MyIASM处理程库逐步取代了ISAM处理程序,这种老式的表 类型己经没有人在用了数据表在硬盘上的文件存储方式:IASM Frm isd ism
2,MyIASM数据表
这是目前中MySQL默认使用的数据表类型。其优点是
数据表在硬盘上的文件存储方式:MyISAM Frm myd myi
3,Merge数据表
这是一种把相同结构的MyIASM数据表组织为一个逻辑单元的方法
数据表在硬盘上的文件存储方式:Merge Frm mrg
4,HEAP数据表
这是一种使用内存的数据表,而且各个数据行的长度固定,这两个特性使得这种类型数据表的检索速度非常快,作为一种临时性的数据表,HEAP在某些特定情况下很有用。
数据表在硬盘上的文件存储方式:Heap Frm
5,BDB数据表
这种数据表支持事务处理机制,具有良好的并发性能
数据表在硬盘上的文件存储方式:BDB Frm db
6,InnoDB数据表
这是最近加入MySQL的数据表类型,有许多新的特性
支持事务处理机制
崩溃后能够立刻恢复
支持外键功能,包括级联删除
具有并发功能
数据表在硬盘上的文件存储方式:InnoDB frm
参考来源:http://www.nowamagic.net/database/db_TypeOfTable.php
同Oracle 和SQL Server等大型数据库系统一样,MySql也是客户/服务器系统并且是单进程多线程架构的数据库。
MySql区别于其它数据库系统的一个重要特点是支持插入式存储引擎。
存储引擎说白了就是如何存储数据、如何为存储的数据建立索引和如何更新、查询数据等技术的实现方法。因为在关系数据库中数据的存储是以表的形式存储的,所以存储引擎也可以称为表类型(即存储和操作此表的类型)。
在Oracle 和SQL Server等数据库中只有一种存储引擎,所有数据存储管理机制都是一样的。而MySql数据库提供了多种存储引擎。用户可以根据不同的需求为数据表选择不同的存储引擎,用户也可以根据自己的需要编写自己的存储引擎。
MySql中有哪些存储引擎?
当然MySql支持的表类型不止上面几种。下面我们介绍一下如何查看和设置数据表类型。
bitsCN.com