浅谈MySql的存储引擎(表类型)

什么是MySql数据库mysql

    一般意义上,数据库也就是数据的集合,具体到计算机上数据库能够是存储器上一些文件的集合或者一些内存数据的集合。
    咱们一般说的MySql数据库,sql server数据库等等实际上是数据库管理系统,它们能够存储数据,并提供查询和更新数据库中的数据的功能等等。根据数据库如何存储数据和如何操做数据的实现机制不一样,这些数据库之间即有区别又有共同点。
    MySql数据库是开放源代码的关系型数据库。目前,它能够提供的功能有:支持sql语言、子查询、存储过程、触发器、视图、索引、事务、锁、外键约束和影像复制等。在后期,咱们会详细讲解这些功能。
    同Oracle 和SQL Server等大型数据库系统同样,MySql也是客户/服务器系统而且是单进程多线程架构的数据库。
    MySql区别于其它数据库系统的一个重要特色是支持插入式存储引擎。 web

那么什么是存储引擎呢?sql

    存储引擎说白了就是如何存储数据、如何为存储的数据创建索引和如何更新、查询数据等技术的实现方法。由于在关系数据库中数据的存储是以表的形式存储的,因此存储引擎也能够称为表类型(即存储和操做此表的类型)。
    在Oracle 和SQL Server等数据库中只有一种存储引擎,全部数据存储管理机制都是同样的。而MySql数据库提供了多种存储引擎。用户能够根据不一样的需求为数据表选择不一样的存储引擎,用户也能够根据本身的须要编写本身的存储引擎。
MySql中有哪些存储引擎?
     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支持的表类型不止上面几种。
数据库

    下面咱们介绍一下如何查看和设置数据表类型。服务器

MySql中关于存储引擎的操做多线程

    1 查看数据库能够支持的存储引擎
    用show engines; 命令能够显示当前数据库支持的存储引擎状况,如图1所示:架构

                                             图1 数据库的存储引擎工具


    由上图可见当前系统的默认数据表类型是MyISAM。固然,咱们能够经过修改数据库配置文件中的选项,设定默认表类型。
    2 查看表的结构等信息的若干命令
    要查看表的定义结构等信息可使用如下几种命令:
    2.1Desc[ribe] tablename; //查看数据表的结构
    例如,查看表t1的结构,可得下图。学习

                                         图2:查看表t1的结构
 
    2.2 Show create table tablename; //显示表的建立语句
    同上查询表t1,得下图:优化

                                          图3 显示建立表t1的语句

 
    2.3 show table status like ‘tablename’\G显示表的当前状态值

     同上查询表t1,得下图:

                    图4 显示表t1 的当前状态值

 
    综上可见,后两种方式均可以帮助咱们查看某一表的存储引擎类型(图中已用红色方框标出)。
    3  设置或修改表的存储引擎
    3.1建立数据库表时设置存储存储引擎的基本语法是:
Create table tableName(
columnName(列名1)  type(数据类型)  attri(属性设置),
columnName(列名2)  type(数据类型)  attri(属性设置),
……..) engine = engineName

例如,假设要建立一个名为user的表,此表包括id,用户名username和性别sex三个字段,而且要设置表类型为merge。则可用以下的方式建立此数据表,

create table user(

  id int not null auto_increment,

  username char(20) not null,

  sex char(2),

  primary key(id)

) engine=merge

具体执行结果见下图:

            图5 建立表user 

                                                                                                                                                                                                                                       

查看建立后表user的信息,可见表的当前存储引擎是merge,如图所示:

             图6 显示表t1 的当前状态值

 

    3.2修改存储引擎,能够用命令Alter table tableName engine =engineName

假如,若须要将表user的存储引擎修改成archive类型,则可以使用命令alter table user engine=archive。以下图所示:

             图7 修改表user的存储引擎

 
查看修改后的表类型,可见表类型已经变为archive类型。

             图8 显示表user修改后的状态值
 
小结
     在本文中主要介绍了什么是MySql数据库,并进一步引出了它的一个重要特性, 即插入式的多存储引擎机制。而后,简单介绍了什么是存储引擎和MySql中几种主要的存储引擎。最后,介绍了如何查看数据库支持的全部存储引擎,如何查看数据库表的存储引擎类型及如何设置或修改表的存储引擎类型。刚刚入门学习MySql,文中有错误之处,还请你们多多指导!

相关文章
相关标签/搜索