MySQL存储引擎

1、存储引擎mysql

存储引擎说白了就是如何存储数据、如何为存储的数据创建索引和如何更新、查询数据等技术的实现方法。由于在关系数据库中数据的存储是以表的形式存储的,因此存储引擎也能够称为表类型(即存储和操做此表的类型)。sql

  1 MyISAM:这种引擎是mysql最先提供的。这种引擎又能够分为静态MyISAM、动态MyISAM 和压缩MyISAM三种:
    静态MyISAM若是数据表中的各数据列的长度都是预先固定好的,服务器将自动选择这种表类型。由于数据表中每一条记录所占用的空间都是同样的,因此这种表存取和更新的效率很是高。当数据受损时,恢复工做也比较容易作。
    动态MyISAM若是数据表中出现varchar、xxxtext或xxxBLOB字段时,服务器将自动选择这种表类型。相对于静态MyISAM,这种表存储空间比较小,但因为每条记录的长度不一,因此屡次修改数据后,数据表中的数据就可能离散的存储在内存中,进而致使执行效率降低。同时,内存中也可能会出现不少碎片。所以,这种类型的表要常常用optimize table 命令或优化工具来进行碎片整理。
    压缩MyISAM以上说到的两种类型的表均可以用myisamchk工具压缩。这种类型的表进一步减少了占用的存储,可是这种表压缩以后不能再被修改。另外,由于是压缩数据,因此这种表在读取的时候要先时行解压缩。
    可是,无论是何种MyISAM表,目前它都不支持事务,行级锁和外键约束的功能。
    2 MyISAM Merge引擎:这种类型是MyISAM类型的一种变种。合并表是将几个相同的MyISAM表合并为一个虚表。常应用于日志和数据仓库。
    3 InnoDB:InnoDB表类型能够看做是对MyISAM的进一步更新产品,它提供了事务、行级锁机制和外键约束的功能。
    4 memory(heap):这种类型的数据表只存在于内存中。它使用散列索引,因此数据的存取速度很是快。由于是存在于内存中,因此这种类型常应用于临时表中。
    5 archive:这种类型只支持select 和 insert语句,并且不支持索引。常应用于日志记录和聚合分析方面。
    固然MySql支持的表类型不止上面几种。数据库

事务:处理操做量大,复杂度高的数据。保证成批的SQL语句要么所有执行,要么所有不执行(原子性)。服务器

外键:可使得两张表关联,保证数据的一致性和实现一些级联操做。一、外键列必须创建了索引,二、外键关系的两个表的列必须是数据类型类似,也就是能够相互转换类型的列。工具

相关文章
相关标签/搜索