Mysql存储引擎__笔记
Mysql存储引擎(表类型):
Mysql数据库:
通常意义上,数据库也就是数据的集合,具体到计算机上数据库可以使存储器上一些文件的集合或者一些内存
数据的内存数据的集合。
Mysql数据库是开放源代码的关系型数据库。目前,它可以提供的功能有:支持sql语言,子查询,存储过程,触发器,视图,索引,
事务,锁,外键约束和影响复制等。在后期,我们会详细讲解这些功能。
同oracle和sql server等大型数据库系统一样,mysql也是客户端/服务器系统并且是单进程多线程架构的数据库。
Mysql区别于其他数据库系统的一个重要特点是支持插入式存储引擎。
存储引擎:
说白了就是如何存储数据,如何为存储数据建立索引和如何更新,查询数据等技术的实现方法。因为在关系数据
的存储是以标的形式存储的,所以存储引擎也可以称为表类型(即存储和操作此表的类型)。
在oracle和sql server等大型数据库系统一样,mysql也是客户/服务器系统并且是单进程多线程架构的数据库。
Mysql区别于其他数据库系统的一个重要特点是支持插入式存储引擎,所有存储管理机制都是一样的。而mysql
数据库提供了多种存储引擎。用户可以根据不同需求为数据表选择不同的存储引擎,用户也可以根据自己的需要
编写自己的存储引擎。
Mysql存储引擎:
1.Mylsam:这种引擎是mysql最早提供的。分为静态mylsam,动态mylsam和压缩mylsam三种:
静态mylsam:如果数据表中的各数据列的长度都是预先固定好的,服务器将自动选择这种表类型。因为数据表
中每一条记录所占用的空间都是一样的,所以这种表存取和更新的效率非常高。当数据受损时,恢复工作也比较
容易做。
动态mylsam:如果数据表中出现varchar,xxxtext或xxxblob字段时,服务器将自动选择这种表类型。相对于
静态mylsam,这种表存储空间较小,但由于每条记录的长度不一,所以多次修改数据后,数据表中的数据就可能
离散的存储在内存中,进而导致执行效率下降。同时,内存中也可能会出现很多碎片。因此,这种类型的表都可以
用optimize table命令或优化工具来进行碎片整理
压缩mylsam:以上说的两种类型的表都可以用mylamchk工具压缩。这种类型的表进一步减少了占用的存储,但
是这种表压缩之后不能再被修改。另外,因为是压缩数据,所以这种表在读取的时候要先进行解压缩。
不管哪种,目前都不支持事务,行级锁和外键约束的功能。
2.mylsam merge引擎:这种类型是mylsam类型的一种变种。合并表是将几个相同的mylsam表合并为一个虚表。
常用于日志和数据仓库。
3.InnoDB:可以看错是对mylsam的进一步更新产品,它提供了事务,行级锁机制和外键约束功能。
4.Memory(heap):这种类型的数据表只存在于内存中。它使用散列索引,所以数据的存储速度非常快。因为是存在于
内存中,所以这种类型常应用于临时表中。
5.archive:这种类型只支持select和insert语句,而且不支持索引。常应用于日志记录和聚合分析方面。
当然mysql支持的表类型不知这几种。
注:笔记部分可能参考其他作者内容的一个记录,这里仅为加深自己对概念的理解,一些可能忘记参考谁的了,所以望见谅。