`
suixinsuoyu12519
  • 浏览: 43862 次
  • 性别: Icon_minigender_2
  • 来自: 北京
社区版块
存档分类
最新评论

MYSQL的数据库引擎(转载)

 
阅读更多

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

 

什么是MySql数据库

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

那么什么是存储引擎呢?

    存储引擎说白了就是如何存储数据、如何为存储的数据建立索引和如何更新、查询数据等技术的实现方法。因为在关系数据库中数据的存储是以表的形式存储的,所以存储引擎也可以称为表类型(即存储和操作此表的类型)。
    在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,文中有错误之处,还请大家多多指导!

分享到:
评论

相关推荐

    MYSQL培训经典教程(共两部分) 1/2

    DATE和TIMESTAMP类型 230 1.3.3.3 TIME类型 233 1.3.3.4 YEAR类型 234 1.3.4 字符串类型 234 1.3.4.1 CHAR和VARCHAR类型 234 1.3.... 1.3.8 使用来自其他数据库引擎的列类型 239 1.4 用在SELECT...

    phpstudy Apache PHP MySQL phpMyAdmin ZendOptimizer

    该程序转载他人,希望帮...MySQL数据库用户名:root,密码root,安装后请重新设置密码。 注意:安装过程中,如有防火墙开启,注册启动服务时,会提示是否信任httpd、mysqld-nt运行,以及端口80、3306等,请选择允许。

    mysql安装配置教程.docx

    - **定义**:MySQL是一种流行的开源关系型数据库管理系统,被广泛应用于各种规模的应用程序中。它以其高性能、可靠性和易用性著称。 - **特点**: - 开放源代码。 - 体积小、速度快。 - 支持多种操作系统。 - ...

    MYSQL培训经典教程(共两部分) 2/2

    DATE和TIMESTAMP类型 230 1.3.3.3 TIME类型 233 1.3.3.4 YEAR类型 234 1.3.4 字符串类型 234 1.3.4.1 CHAR和VARCHAR类型 234 1.3.... 1.3.8 使用来自其他数据库引擎的列类型 239 1.4 用在SELECT...

    Linux常见服务功能

    知识点: Mysql 是一个提供了 SQL 数据库引擎服务,能够提供快速高效可靠的轻型 SQL 数据库引擎。 21. Named:提供了域名服务器服务。 知识点: Named 是一个提供了域名服务器服务,能够提供域名服务器功能,负责...

    jBPM-jPDL学习笔记——流程设计与控制(转载)

    在`jbpm.jpdl.mysql.sql`文件中,包含了创建jBPM所需的MySQL数据库表的SQL脚本。这通常包括流程实例表、任务实例表、变量实例表等。 5. **项目结构**: `src`目录通常包含流程定义文件(jPDL文件)、业务逻辑代码...

    ruby on rails, 非常棒的启蒙教材(转载)

    关于数据库,Rails默认使用SQLite,但也可轻松切换到MySQL、PostgreSQL等其他数据库。数据库迁移是Rails中的一个重要概念,通过编写Ruby代码来描述数据库结构的变化,然后使用`rake db:migrate`命令应用这些变化。 ...

    使用open source产品组装你的web应用架构(转载)

    同时,各种库(如数据库操作库、模板引擎、认证和授权库)也是必不可少的,它们提供了常用功能的标准化实现。 4. **数据库**:MySQL、PostgreSQL、MongoDB等是常见的数据库选择。关系型数据库如MySQL适合结构化数据...

    php卡盟程序源码

    3. 数据库管理:PHP程序通常使用MySQL作为后端数据库,存储商品信息、用户数据、订单记录等。数据库设计需遵循关系型数据库原理,如表结构设计、索引优化和事务处理,以确保数据的一致性和高效检索。 4. 用户认证与...

    Borland_C++Builder_6程序设计经典

    再者,C++Builder 6提供了强大的数据库访问能力,支持多种数据库引擎如InterBase、Oracle、MySQL等。书中可能涵盖了ADO(ActiveX Data Objects)和BDE(Borland Database Engine)的使用,以及如何设计和操作数据库...

    安卓智门户织梦整站源码

    织梦(DedeCMS)是这个系统的核心,它是一款广泛应用的内容管理系统,以其灵活的模板引擎和强大的管理功能著称。 在PHP类库中,可能包含了处理用户注册、登录、权限管理、内容发布、评论互动等功能的模块。这些模块...

    Qt4实用教程

    2. 添加MySQL数据库驱动插件、执行SQL语句:这包括了如何将数据库驱动添加到Qt项目中以及如何使用Qt来操作数据库执行查询。 3. 使用模型/视图结构管理数据:解释了Qt中使用QSqlQueryModel、QSqlTableModel、...

    一米阳光项目转载phpwind668—关于PHP

    PHP 支持多种数据库,如 MySQL,能够实现动态网页内容的生成。PHP 的语法简洁且功能强大,允许开发者快速地编写出功能丰富的应用程序。 在学习PHP的过程中,你需要掌握以下几个关键点: 1. 变量与数据类型:PHP ...

    thinkPHP5快速入门手册

    - **数据库驱动选择**:支持多种数据库类型,如MySQL、SQLite等。 - **事务处理**:提供事务管理的方法,确保数据操作的一致性和完整性。 - **查询缓存**:介绍如何利用查询缓存优化数据库访问速度。 #### 五、查询...

    Learning Node.js Development

    - **数据库交互**:掌握如何使用MySQL、MongoDB等常见数据库,并实现CRUD(创建、读取、更新、删除)操作。 - **中间件使用**:了解Express框架中的中间件概念及其在处理请求过程中的作用,包括错误处理和日志记录。...

    treeking_node_qsbk:这是一个用node写的仿糗事百科

    3. **数据库操作**:为了存储和检索用户提交的糗事,项目可能使用了MongoDB、MySQL等数据库,需要了解NoSQL或SQL的基本概念和操作。 4. **前端技术**:HTML、CSS和JavaScript(可能包括React、Vue或Angular等库/框架...

Global site tag (gtag.js) - Google Analytics