转载自 http://www.cnblogs.com/lina1006/archive/2011/04/29/2032894.html

什么是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, 文中有错误之处,还请大家多多指导!

转载于:https://www.cnblogs.com/chenying99/archive/2012/09/01/2666526.html

浅谈MySql的存储引擎(表类型)相关推荐

  1. 浅谈 MySQL 的存储引擎(表类型)

    什么是MySql数据库 通常意义上,数据库也就是数据的集合,具体到计算机上数据库可以是存储器上一些文件的集合或者一些内存数据的集合. 我们通常说的MySql数据库,sql server数据库等等其实是 ...

  2. 支付宝的数据库是MySQL变种_浅谈MySql的储存引擎(表类型)

    浅谈mysql的存储引擎(表类型) 什么是MySql数据库 通常意义上,数据库也就是数据的集合,具体到计算机上数据库可以是存储器上一些文件的集合或者一些内存数据的集合. 我们通常说的MySql数据库, ...

  3. mysql存储引擎静态表_MySQL存储引擎(表类型)的选择

    一.MySQL存储引擎概述 MySQL与多数数据库不同的是包含存储引擎这一特性,用户可以根据应用的需要选择合适的存储引擎来使存储和索引数据,以及是否使用事务等.MySQL5.0支持的存储引擎包括MyI ...

  4. 数据库服务器不支持innodb存储引擎,MySQL InnoDB存储引擎表损坏恢复指南

    目的 故障排除步骤 适用于: MySQL服务器版本 5.0至5.7[5.0版到5.7] A 第一反应 A.1 停止,备份,重启 停止MySQL 服务器.如果它已经下线或崩溃,跳到步骤 2. 代码: / ...

  5. mysql技术内幕innodb存储引擎——表索引算法和锁_(转)Mysql技术内幕InnoDB存储引擎-表索引算法和锁...

    表 原文:http://yingminxing.com/mysql%E6%8A%80%E6%9C%AF%E5%86%85%E5%B9%95innodb%E5%AD%98%E5%82%A8%E5%BC% ...

  6. 浅谈MySQL存储引擎-InnoDBMyISAM

    浅谈MySQL存储引擎-InnoDB&MyISAM 存储引擎在MySQL的逻辑架构中位于第三层,负责MySQL中的数据的存储和提取.MySQL存储引擎有很多,不同的存储引擎保存数据和索引的方式 ...

  7. 浅谈MySQL表类型

    小小子的文章写的不错哦. 转载:http://www.xiaoxiaozi.com/2009/07/14/1171/ 浅谈MySQL表类型 MySQL为我们提供了很多表类型供选择,有MyISAM.IS ...

  8. MySQL如何修改表的储存方式_修改mysql默认存储引擎的方法

    修改mysql默认存储引擎的方法,供大家学习参考. 先来了解一下mysql存储引擎: mysql服务器采用了模块化风格,各部分之间保持相对独立,尤其体现在存储架构上.存储引擎负责管理数据存储,以及my ...

  9. MySQL存储引擎 lnnoDB逻辑架构 innodb存储引擎表空间(ibd文件)详解 回滚日志的物理空间

    文章目录 存储引擎 一 MySQL组织架构 二 查看存储引擎信息 三 修改存储引擎 3.1 配置文件修改存储引擎 3.2 临时修改存储引擎 3.3 建表时修改存储引擎 四 存储引擎实验 五 数据库升级 ...

最新文章

  1. 利用Python模拟鼠标自动完成MM32-LINK程序下载
  2. 使用 flex 实现 5 种常用布局
  3. python nDPI 流量分析框架 Nfstream 简介
  4. 项目打包去掉调试时的NSLog、print
  5. 谷歌杀手Wolfram Alpha搜索引擎上线测试
  6. 速卖通2022新开店入驻流程及费用
  7. JAVA标识符中含小数点可以吗_数值类型小数点后是否可以接零问题
  8. python实现定时任务的方式_Python实现定时执行任务的三种方式简单示例
  9. Python-接口开发入门
  10. 在Centos环境下搭建Confluence
  11. ICS Pwn2Own 2022迈阿密黑客大赛的目标和奖金公布
  12. 拓端tecdat|使用R语言进行Metroplis-in-Gibbs采样和MCMC运行分析
  13. w10系统服务器管理器,Win10如何打开服务管理器
  14. 便捷式计算机无线功能按钮,便携式wlan热点是什么 如何设置【图解】
  15. 如何用PPT制作一份数据图表?
  16. ESP32-NVS存储(非易失性存储库)
  17. 文件搜索工具(Python实现)
  18. 多媒体个人计算机能处理什么,多媒体信息处理
  19. 从零学Java(19)之 if else分支结构详解,小AD要搞对面心态!
  20. Centos中Samba共享目录无法访问

热门文章

  1. 朴素贝叶斯(Naive Bayesian)
  2. 六时出行 App 隐私政策
  3. MySQL管理工具HeidiSQL
  4. 一个按钮触发多个a标签,只有一个可以下载,其他的window.open()被浏览器拦截...
  5. noi 3531 判断整除
  6. InfoPath的常见问题---连接外部数据源提示
  7. 用Express搭建 blog (一)
  8. LeetCode--81. 搜索旋转排序数组Ⅱ(遍历法,二分法)
  9. PocketSphinx语音识别系统的编译、安装和使用
  10. idea怎么导入jxl.jar库