1.Mysql中的数据用各种不同的技术存储在文件中,这些技术中的每一种技术都使用不同的存储机制,索引技巧,锁定水平并且最终
提供广泛的不同功能和能力,在Mysql中这些不同的技术以及配套的相关功能职为存储引擎。
2.存储引擎其实就是对与数据库文件的一种存储机制,如何实现存储数据,如何为存储的数据建立索引以及如何更新,查询数据等
技术实现的方法。
3.mysql存储引擎总共有九种,常用的数据引擎有MyISAMInnoDB
查看mysql支持的引擎命令:show engines
mysql 5.5以及更高的版本,默认的存储引擎是InnoDB
5.5之前是MyISAM
4.MyISAM和InnoDB的区别?
MYISAM存放的方式:MyISAM这种存储引擎不支持事务,不支持行级锁,支持并发插入的表锁,主要用于高负债的select
索引的方式:MyISAM也是使用B+tree索引但是和Innodb的具体实现上有些不同
优缺点:MyISAM的有事在于占用空间小,处理书读快,缺点是不支持事务的完整性和并发性
存放的方式:innodb支持自增长列(auto_increment),自增长列的值不能为空,如果在使用的时候为空的话怎会进行自动存现有的值开始增值,如果有但是比现在的还大,则就保存这个值。
innodb存储引擎支持外键(foreign key) ,外键所在的表称为子表而所依赖的表称为父表。
innodb存储引擎最重要的是支持事务,以及事务相关联功能。支持mvcc的行级锁。
索引的方式:innodb存储引擎索引使用的是B+Tree。
优缺点:InnoDB的优势在于提供了良好的事务处理、崩溃修复能力和并发控制。缺点是读写效率较差,占用的数据空间相对