存储引擎
也叫做表类型,指的是数据表的存储机制、索引方案等配套的相关功能,不同的存储引擎,由于处理的方式不用,会带来不同的功能或优化,也就是说,各有各的优点!
所以,用户在创建表的时候,应该根据实际的需要选择合理的存储引擎!
默认值为InnoDB,当然,可以在配置文件my.ini中进行修改:
如果进行了修改,需要重启MySQL服务器才能生效!
我们通过show engines;来查询所有的存储引擎:
在所有的存储引擎中,最最常用的有两个:
- InnoDB
- Myisam
1 create table yinqing(2 a int,3 b float4 )default charset utf8 engine Myisam;
此时在该表的数据库目录下
为什么有三个文件?
一个数据表,其实有三部分构成:
结构
数据
索引
而Myisam存储引擎的数据表其实就是将以上的三个部分分开进行存储!
而InnoDB存储引入的数据表,在数据库目录下只保存了表结构部分:
而数据和索引两个部分其实都在同一个数据空间内:
InnoDB与Myisam的比较:
InnoDB的数据更新速度比较快,插入和查询较慢,支持事务和外键
Myisam的插入和查询速度比较快,但是数据更新速度比较慢