前言

  • 存储引擎的实质就是如何实现存储数据,为存储的数据建立索引以及查询、更改、删除数据等技术实现的方法
  • 不同于很多数据库系统仅仅选择一种类型的数据存储方式,MySQL 数据库支持多种不同的数据引擎
  • 可以根据具体的要求,针对每一个表使用不同的数据引擎,摒弃了很多其他数据库采取的“一个尺码满足一切需求”的解决方案
  • 正是这种灵活性,使得 MySQL 数据库更加受欢迎

一、MyISAM 存储引擎

1.存储引擎介绍

  • MySQL 中的数据用各种不同的技术存储在文件中
  • 这些技术中心的每一种技术都使用不同的存储机制、索引技巧、锁定水平并且最终提供广泛的不同的功能和能力
  • 通过选择不同的技术,能够获得额外的速度或者功能,从而改善应用的整体功能
  • 这些不同的技术以及配套的相关功能在 MySQL 中被称作存储引擎
  • MySQL 提供了多个不同的存储引擎,可以预先设置或者在 MySQL 服务器中启用
  • 根据实际需要还可以分别选择适用于服务器、数据库或者表格的存储引擎,以便在后续检索这些信息等操作过程中提供最大的灵活性
  • 可以看出,MySQL 的核心就是在其存储引擎之上
  • MySQL 提供了一系列标准的管理和服务支持,这些标准和存储引擎无关,是每个数据库本身所必须的;而存储引擎是底层物理结果的实现,每个开发者都可以按照自己的意愿来开发或者修改存储引擎的内容
  • MySQL 支持插件式的表存储引擎,这种独有的插件式体系结构,让存储引擎有了依赖于应用的多样性
  • 开发人员能根据应用的不同特点,选择合适的存储引擎
  • 如果如果存储引擎不能满足要求的话,还可以定制合适自己应用的存储引擎
  • eBay、Google、Facebook 等公司都对 MySQL 引擎做过改进,以满足自己的业务特性
  • 最为知名的是 MyISAM 和 InnoDB 存储引擎
  • MySQL 系统中,存储引擎处于文件系统之上,在数据保存到数据文件之前会传输到存储引擎,然后按照各个存储引擎的存储格式进行存储
  • 使用这种存储引擎的主要优点在于,仅仅需要提供特殊应用所需的特性即可;数据库中的系统开销较小;具有更有效和更高效的数据库性能

2.MyISAM 的介绍

  • MyISAM 存储引擎是 MySQL 关系数据库系统 5.5 版本之前的存储引擎,它的前身就是 ISAM
  • ISAM 是一个定义明确且历经时间考验的数据表格管理方法,它在设计之时就考虑到数据库被查询的次数要远大于更新的次数
  • 因此,ISAM 执行读取操作的速度很快,而且不占用大量的内存和存储资源
  • ISAM 的两个主要不足之处在于,它不支持事务,也不能够容错,如果硬盘崩溃了,那么数据文件就无法恢复了
  • 如果正在把 ISAM 用在关键任务应用程序里,那就必须经常备份所有的实时数据,通过其复制特性,MySQL 就能够支持这样的备份应用程序
  • MyISAM 管理非事务表,是MySQL 的 ISAM 扩展格式
  • 除了提供 ISAM 里没有的索引字段管理的大量功能,MyISAM 还使用一种表格锁定的机制,来优化多个并发的读写操作
  • MySIAM 提供告诉存储和检索,以及全文搜索能力,从而受到 Web 开发者的青睐,因为在 Web 开发过程中需要进行大量的数据读取操作

3.MyISAM 的特点

MySIAM 对数据读取有非常好的支持,MyISAM 存储引擎的一些特点如下:

  1. 不支持事务,不需要事务支持的系统能使用 MyISAM 作为存储引擎
  2. 表级锁定形式,数据在更新时锁定整个表
  3. 数据库在读写过程中相互阻塞:
    1. 在数据写入的过程阻塞用户对数据的读取
    2. 会在数据读取的过程中阻塞用户的数据的写入
  4. 可以通过设置缓存索引来提高访问的性能,减少磁盘 IO 的压力
  5. 采用 MyISAM 存储引擎进行数据单独写入或读取,速度较快且占用资源相对要少,适合查询、插入为主的应用
  6. MyISAM 存储引擎不支持外键约束只支持全文索引,数据文件和索引文件是分开保存的
  7. 每个 MyISAM 在磁盘上存储成三个文件,每一个文件的名字均以表的名字开始,扩展名指出文件类型
    1. .frm 文件存储表定义
    2. 数据文件的扩展名为 .MYD (MYData)
    3. 索引文件的扩展名是 .MYI (MYIndex)

4.MyISAM 支持的存储格式

支持三种不同的存储格式:

  1. 静态(固定长度)表

    1. 静态表是默认的存储格式
    2. 静态表中的字段都是非可变字段,这样每个记录都是固定长度的
    3. 这种存储方式的优点是存储非常迅速,容易缓存,出现故障容易恢复
    4. 缺点是相对而言,占用的空间通常比动态表多
  2. 动态表
    1. 动态表包含可变字段,记录不是固定长度的
    2. 这样存储的优点是占用空间较少,但是频繁的更新、删除记录会产生碎片
    3. 需要定期执行 OPTIMIZETABLE 语句或 myisamchk -r 命令来改善性能
    4. 并且出现故障的时候恢复相对比较困难
  3. 压缩表
    1. 压缩表由 myisamchk 工具创建,占据非常小的空间
    2. 因为每条记录都是被单独压缩的,所以只有非常小的访问开支

5.MyISAM 适用的生产场景举例

在生产环境中,需要根据场景的实际情况,选择核实的存储引擎,下面举两个例子,说明在什么场景中选择使用 MyISAM 存储引擎

场景一:

  1. 公司业务不需要事务的支持,这点是非常明确的,因为 MyISAM 没有事务
  2. 一般单方面读取或写入数据比较多的业务,因为 MyISAM 具有读写互相阻塞的特点,数据读写都比较频繁的场景不适合使用
  3. 使用读写并发访问相对较低的业务
  4. 数据修改相对较少的业务

场景二:

  1. 公司的业务不需要事务的支持
  2. 一般单方面读取数据比较多的业务,或单方面写入数据比较多的业务,以及读写并发访问相对较低的业务
  3. 以读为主的业务,如 www、blog 图片信息库、用户数据库、商品库等业务
  4. 对业务一致性要求不是非常高的业务
  5. 服务器硬件资源相对比较差

二、InnoDB 存储引擎

1.InnoDB 的介绍

  • InnoDB 存储引擎不同于 MyISAM 存储引擎,能够支持事务安全镖(ACID 兼容),具有提交、回滚和崩溃恢复的能力
  • InnoDB 支持行级锁定,并且可以在 SELECT 语句中提供一个与 Oracle 风格类似的非锁定读,也支持 FOREIGN KEY 强制
  • 种种特性使得 InnoDB 存储引擎的多用户部署和性能得以提升
  • InnoDB 存储引擎还支持 SQL 查询中将 InnoDB 类型的表与其他 MySQL 的表类型混合使用,甚至在同一个查询中也可以混合使用
  • InnoDB 是为处理巨大数据量时的最大性能而设计的
  • 它的 CPU 效率可能是任何其他基于磁盘的关系数据库引擎所不能匹敌的
  • InnoDB 存储引擎被完全与 MySQL 服务器整合,为在内存中缓存数据和索引而维持它自己的缓冲池
  • InnoDB 在一个表空间中存储它的表与索引,表空间可以包含数个文件(或原始磁盘分区)
  • 这与 MyISAM 不同,比如在 MyISAM 表中每个表被存储在分离的文件中
  • InnoDB 表可以是任何尺寸,即使在文件尺寸被限制为 2GB 的操作系统上也无影响

2.InnoDB的 特点

  1. 支持事务,支持四个事务隔离级别
  2. 行级锁定,但是全表扫描仍然会是标记锁定
  3. 读写阻塞与事务隔离级别相关
  4. 具有非常高效的缓存特性,能缓存索引,也能缓存数据
  5. 表与主键以簇的方式存储
  6. 支持分区、表空间,类似 Oracle 数据库
  7. 支持外键约束,MySQL 5.5 以前不支持全文索引,5.5 版本以后支持
  8. 适合对硬件资源要求比较高的场合

3.InnoDB 适用的生产场景

根据 InnoDB 的特点,在下面的场景中需要选择适用 InnoDB 存储引擎

  1. 业务需要事务的支持
  2. 行级锁定对高并发有很好的适应能力,但需要确保查询时通过索引来完成
  3. 业务数据更新较为频繁的场景,如论坛、微博等
  4. 业务数据一致性要求较高,例如银行业务
  5. 硬件设备内存较大,利用 InnoDB 较好的缓存能力来提高内存利用率,减少磁盘 IO 的压力

4.企业选择存储引擎的依据

选择哪种存储引擎,应根据企业系统的实际需要,考虑每个存储引擎提供了哪些不同的核心功能及应用的常见
主要依据以下几个方面来决定:

  1. 存储引擎支持的字段和数据类型

    1. 所有的引擎都支持通用的数据类型,但不是所有的引擎都支持其他的字段类型
    2. 如二进制对象
  2. 锁定类型
    1. 不同的存储引擎支持不同级别的锁定
    2. 表锁定:MyISAM 支持
    3. 行锁定:InnoDB 支持
  3. 索引的支持
    1. 建立索引在搜索和恢复数据库中的数据时能够显著提高性能
    2. 不同的存储引擎提供不同的制作索引的技术
    3. 有些存储引擎根本不支持索引
  4. 事务处理的支持
    1. 事务处理功能提供向表中更新和插入信息期间的可靠性
    2. 可根据企业业务是否要支持事务选择存储引擎

5.小结

  • InnoDB 中不保存表的行数,需要扫描一遍整个表来计算有多少行,但是 MyISAM 只要简单的读出保存好的行数即可
  • 需要注意的是,当"count( )"语句包含 where 条件时,MyISAM 也需要扫描整个表
  • 对于自增长的字段,InnoDB 中必须包含只有该字段的索引,但是在 MyISAM 表中可以和其他字段一起建立组合索引
  • 清空整个表时,InnoDB 是一行一行的删除,效率非常慢;而MyISAM 则会重建表

三、配置合适的存储引擎

选择了合适的存储引擎之后,就可以修改为相应的存储引擎类型,修改的步骤如下:

  1. 查看数据库可配置的存储引擎类型
  2. 查看表正在使用的存储引擎类型
  3. 配置存储引擎为所选择的类型

1.查看数据库可配置的存储引擎类型

show engines;
参数 解释
Engine 当前版本的 MySQL 所支持的引擎类型
Support 对应引擎是否能使用,DEFAULT 指默认值
Comment 存储引擎的简要说明
Transactions 对应引擎是否支持事务
XA 存储引擎是否支持XA事务
Savepoints 存储引擎是否支持保存点

2.查看表正在使用的存储引擎类型

2.1 方式一

show table status from 库名 where name = '表名'\G;
#加\G能竖向查看,不加则是横向例:
show table status from school where name='class'\G;

2.2 方式二

use 库名;
show create table 表名;例:
use school;
show create table class\G;

3.配置存储引擎为所选择的类型

3.1 方法一

#通过使用 alter table 命令修改use 库名;
alter table 表名 engine=MyISAM;例:
use school;
alter table class engine=myisam;
show create table class;

3.2 方法二

#通过修改 MySQL 的配置文件 my.cnf,可以指定 default-storage-engine 选项设置默认的存储引擎quitvim /etc/my.cnf
[mysqld]
default-storage-engine=INNODBsystemctl restart mysql.service
#一定记得重启服务以让修改的配置生效#注:此方法只针对新建的表,对以前已存在的表没有影响,即不会修改之前表的存储引擎类别

3.3 方法三

#通过使用 create table 创建表时用 engine 指定存储引擎,会使用指定的存储引擎use 库名;
create table 表名(字段1 数据类型,...) engine=MyISAM;例:
mysql -uroot -p123123use school;
create table xcf123 (name varchar(10),age char(4))engine=myisam;show create table xcf123;

MySQL 数据库--存储引擎相关推荐

  1. MySQL—05—MySQL如何处理SQL语句;MySQL数据库存储引擎介绍;

    一. MySQL 中的执行计划 1 MySQL 执行计划 在 MySQL 中可以通过 explain 关键字模拟优化器,执行 SQL 语句,从而知道 MySQL 是 如何处理 SQL 语句的. 2 M ...

  2. mysql数据库存储引擎和索引的描述_Mysql InnoDB引擎的索引与存储结构详解

    前言 在Oracle 和SQL Server等数据库中只有一种存储引擎,所有数据存储管理机制都是一样的. 而MySql数据库提供了多种存储引擎.用户可以根据不同的需求为数据表选择不同的存储引擎,用户也 ...

  3. MYSQL数据库--存储引擎

    前言 数据库存储引擎是数据库底层软件组件,数据库管理系统使用数据引擎进行创建.查询.更新和删除数据操作.简而言之,存储引擎就是指表的类型.数据库的存储引擎决定了表在计算机中的存储方式.不同的存储引擎提 ...

  4. Mysql数据库存储引擎--转

    原文地址:http://pangge.blog.51cto.com/6013757/1303893 简单介绍 存储引擎就是指表的类型.数据库的存储引擎决定了表在计算机中的存储方式.存储引擎的概念是My ...

  5. mysql数据库存储引擎

    我们在<MySQL存储引擎有哪些>一节中介绍了 MySQL 中几种主要的存储引擎以及它们的使用特性,本节将介绍如何根据不同的应用场景去选择合适的存储引擎.   在使用 MySQL 数据库管 ...

  6. MySQL 数据库存储引擎

    目录 一.存储引擎简介 二.MyISAM存储引擎 1.MylSAM介绍 2.MyISAM表支持3种不同的存储格式 3.MylSAM的特点 4.MyISAM使用的生产场景 三.InnoDB存储引擎 1. ...

  7. 「MySQL 数据库 存储引擎」InnoDB和MyIsAm的区别

    我们应该深刻意识到Mysql数据库的核心为存储引擎 MySql数据库的插件型体系结构,可以使用不同的存储引擎-- 而每个存储引擎都有各自的特点,开发人员可以根据不同的业务和应用建立不同的存储引擎表. ...

  8. MySQL 数据库存储引擎介绍

    文章目录 一.存储引擎概念介绍 二.MyISAM 存储引擎 1. MyISAM 简介 2. MyISAM 表支持 3 种不同的存储格式 (1) 静态(固定长度)表 (2) 动态表 (3) 压缩表 3. ...

  9. MySQL数据库存储引擎以及数据库的创建、修改与删除

    文章目录 MySQL存储引擎 InnoDB存储引擎 MyISAM储存引擎 Memory存储引擎 Archive存储引擎 数据库的相关操作 创建数据库 修改数据库 删除数据库 查看数据库列表 打开数据库 ...

最新文章

  1. c++一日一练:利用流来实现读和写的同步(原创)
  2. linux c 函数 link symlink unlink 链接相关功能
  3. 随机文件名生成可用于文件上传(图片)
  4. 【C语言进阶深度学习记录】十四 C语言中 三目运算符和逗号表达式
  5. [转贴]非技术:在广州天河北被抢全记录(入面D广州话真系厉害,不懂粤语者别看,会吐血)...
  6. jquer同时选择多个不同的id执行同意操作
  7. 【Matlab学习笔记】【细胞或颗粒检测分割】资源汇总
  8. java调用lingo实例_LINGO使用教程(一)
  9. 超赞,1万字的后端面试题及面试经验分享!
  10. 操作WORD文件:使用MSWORD.OLB组件将RichTextBox中的文本保存为WORD格式文件。
  11. 切片器可以设置日期格式?_在Power BI中设置切片器的默认值,你会吗?
  12. 公安部中标十大身份证阅读器品牌型号
  13. 给IDEA换个酷炫的主题,真的太好看了!
  14. 今天写了个自定义函数验证身份证号是否符合规则
  15. 人群异常聚集识别监测
  16. mysql安装教程_mysql 5.5 安装配置方法图文教程
  17. 微机原理_第1章 微型计算机概述
  18. unicode 生僻字_生僻字打不出来怎么办?教你一招轻松应对!
  19. springboot/springcloud整合mybatis(mysql)
  20. 开源项目推荐:HandsFree机器人项目

热门文章

  1. 计算机生成全息投影代码,常见的投影控制代码 汇总 1
  2. 单片机线选法存储印象(地址范围)方法+例题
  3. 用RIO包健壮地读写
  4. vi/vim简介及使用教程
  5. Scratch冰雹猜想
  6. 神经网络与深度学习笔记(三)python 实现反向传播算法
  7. Python数据分析之pandas(保姆级教程)
  8. Swift 笔记(十)
  9. android 请假单界面,请假单_表单设计_OA系统_泛普软件
  10. Make和Makefile