影响数据库性能的因素:

1、硬件环境:CPU、内存、存盘IO、网卡流量等

2、存储引擎的选择

3、数据库参数配置(影响最大)

4、数据库结构设计和SQL语句

MySQL采用插件式存储引擎,可以自行选择,但同时如何选择也成了问题,本文会介绍存储引擎的特点,以及如何选择

MySQL体系结构:

Server用来实现所有与存储引擎无关的事:比如,查询语句等

MySQL所支持的存储引擎如下:通过show engines查询

MyISAM:MySQL5.5版本之前默认的存储引擎

MyISAM的表由FRM(存储表定义)、MYD(数据文件)和MYI(索引文件)组成,后面两个为MyISAM独有的

特性:

1、并发性和锁级别:

  使用表级锁,对数据进行读取和修改的时候,都会对表进行加锁,读写互斥,对读写混合的并发不好,对只读的并发还可以

2、表损坏修复:

  支持对意外关闭导致损坏的表进行检查和修复(不是事务恢复,因为MyISAM不是事务型引擎,没有事务恢复的相关日志),通过

check table tablename和repair table tablename进行检查和修复,也可以通过MyISAMCHK进行修复,但是一定要先将mysql服务停止

3、支持全文索引:

  是5.7版本之前唯一原生就支持全文索引的引擎

4、对只读表可以进行数据压缩:

  通过MyISAMPack对文件进行压缩,压缩过后就变成只读表了,不能修改数据

5、独有的系统表和临时表

临时表是指在排序、分组等操作中,当数据超过一定大小时,由查询优化器创建的临时表,而不是CREATE TEMPORARY TABLE创建这种临时表

限制:

  1、5.0版本之前默认表大小为4G,想要存储更大的表要修改MAX_rows和AVG_ROW_LENGTH,相乘就是表大小

  2、5.0版本之后默认256T

使用场景:

  1、不支持事务的应用

  2、只读类应用,可以对文件的压缩

  3、5.0之前,只有MyISAM支持空间类应用,可以存储例如GPS型数据

  4、大数据select场景

InnoDB:5.5版本之后默认存储引擎,代替了MyISAM

特性:

  1、支持事务,支持ACID特性,通过Redo Log(已提交的事务)和Undo Log(未提交的事务)

  2、支持行级锁,在存储引擎层实现,可以支持更大的并发

  3、使用表空间进行数据存储:通过show variables like 'innodb_file_per_table';进行查看

  值为ON,为每个表创建一个表空间:tablename.ibd

  值为OFF,使用系统表空间ibdataX(X为数字,1,2,3,4,5)

如何选择表空间存储方式:

  1、5.5之前默认使用系统表空间,表空间大小不会变,即使磁盘空间不足,主动删除一些信息,表空间不会改变

  2、独立表空间可以通过命令:optimize table来收缩系统文件

  3、系统表空间可能会存在IO瓶颈

  4、独立表空间可以同时向多个文件刷新数据,IO问题要小得多

V5.6之后,独立表空间变成默认,也是建议使用的

MyISAM与InnoDB区别:

  1).InnoDB支持事务,MyISAM不支持

  2).MyISAM适合查询以及插入为主的应用,InnoDB适合频繁修改以及涉及到安全性较高的应用

  3).InnoDB支持外键,MyISAM不支持

  4).V5.7版本之后,InnoDB支持了全文索引和空间函数,所以MyISAM使用场景越来越少,一般都是使用InnoDB

  5).InnoDB中不保存表的行数,如select count(*) from table时,InnoDB需要扫描一遍整个表来计算有多少行,但是MyISAM只要简单的读

出保存好的行数即可。注意的是,当count(*)语句包含where条件时MyISAM也需要扫描整个表

  6).MYISAM的性能更优,占用的存储空间少.MYISAM索引和数据是分开的,而且其索引是压缩的,可以更好地利用内存。所以它的查询性能明

显优于INNODB

  7).对于自增长的字段,InnoDB中必须包含只有该字段的索引,但是在MyISAM表中可以和其他字段一起建立联合索引

  8).清空整个表时,InnoDB是一行一行的删除,效率非常慢。MyISAM则会重建表

  9).MyISAM支持表级锁,InnoDB支持行锁(某些情况下还是锁整表,如 update table set a=1 where user like '%lee%',或者where条件

没有使用主键)

CSV:

  1、CSV可以将CSV文件当做MySQL表进行处理,CSV数据是以CSV文件的格式进行存储

  2、所有列必须都是非空的

  3、不支持索引

  4、可以对数据文件直接进行编辑,其他存储引擎的数据都是以二进制的形式进行存储

使用场景:

  适合作为数据交换的中间表,例如可以将Excel的数据存储为CSV文件,直接复制到MySQL目录,就可以直接打开使用,反过来也是一样的

Archive:

  1、以zlib对表数据进行压缩,比MyISAM占用的磁盘IO更少

  2、数据存储在.ARZ文件中,.frm存储表结构信息

  3、只支持insert和select操作,支持高并发

  4、只支持在自增ID上加索引

使用场景:

  日志和数据采集类的应用

Memory:

  也被称为heap存储引擎,数据都是保存在内存当中,所以只存在.frm文件

  1、MySQL重启之后,Memory存储引擎对应的表数据都会消失,但是表结构存在,因为保存在.frm文件中

  2、支持hash索引和BTree索引,默认hash索引(使用与=查询),如果更多的是范围查询使用BTree索引

  3、所有字段的长度都是固定的,例如

  4、不能使用BLOG和TEXT这类大字段

  5、使用的是表级锁

  6、MEMORY支持AUTO_INCREMENT列和对可包含NULL值的列的索引

  7、存储数据最大大小由max_heap_table_size参数决定,可以自行修改

使用场景:

  1、适用于等值查找,可用于查找和映射表,邮编和地区的映射

  2、保存数据分析的中间表

  3、缓存周期性聚合数据的结果表

总体就是:因为Memory的数据容易丢失,要求数据可再生

PS:主从复制不能保证Memory数据,master重启会重建表,slave也会重建的

如何选择存储引擎:

1、应用需要事务支持,就选用InnoDB

2、应用是否需要数据备份,一般生产环境都需要热备,也是InnoDB

3、崩溃恢复,InnoDB也比MyISAM更稳定

4、上面都不考虑的情况下,再考虑存储引擎的特性,特性再上面都已经基本总结到了

PS:尽量不要混合使用存储引擎,不然可能发生很奇怪的问题

MySQL系列(二)--MySQL存储引擎的更多相关文章

  1. Mysql系列二:Mysql 开发标准规范

    原文链接:http://www.cnblogs.com/liulei-LL/p/7729983.html 一.表设计 1. 库名.表名.字段名使用小写字母,“_”分割. 2. 库名.表名.字段名不超过 ...

  2. MySQL内核:InnoDB存储引擎 卷1

    MySQL内核:InnoDB存储引擎卷1(MySQL领域Oracle ACE专家力作,众多MySQL Oracle ACE力捧,深入MySQL数据库内核源码分析,InnoDB内核开发与优化必备宝典) ...

  3. 一生挚友redo log、binlog《死磕MySQL系列 二》

    系列文章 原来一条select语句在MySQL是这样执行的<死磕MySQL系列 一> 一生挚友redo log.binlog<死磕MySQL系列 二> 前言 咔咔闲谈 上期根据 ...

  4. MySQL开发篇,存储引擎的选择真的很重要吗?

    前言 谁说MySQL查询千万级别的数据很拉跨?我今天就要好好的和你拉拉家常,畅谈到深夜,一起过除夕!这篇文章也是年前的最后一篇,希望能带给大家些许收获,不知不觉查找文档和参考实体书籍就写了这么多,自己 ...

  5. MySQL表类型和存储引擎

    一.基本介绍 从事务安全性的角度,可以把存储引擎分为两大类: 事务安全: BDB和innodb; 事务非安全性: myisam 和 memory 二.存储引擎的比较图 看你的mysql当前默认的存储引 ...

  6. 《mysql技术内幕 InnoDB存储引擎(第二版)》阅读笔记

    一.mysql架构 mysql是一个单进程多线程架构的数据库. 二.存储引擎 InnoDB: 支持事务 行锁 读操作无锁 4种隔离级别,默认为repeatable 自适应hash索引 每张表的存储都是 ...

  7. mysql 数据表操作 存储引擎介绍

    一 什么是存储引擎? 存储引擎就是表的类型. mysql中建立的库===>文件夹 库中建立的表===>文件 现实生活中我们用来存储数据的文件有不同的类型,每种文件类型对应各自不同的处理机制 ...

  8. Mysql技术内幕——InnoDB存储引擎

    Mysql技术内幕——InnoDB存储引擎 http://jingyan.baidu.com/article/fedf07377c493f35ac89770c.html 一.mysql体系结构和存储引 ...

  9. mysql修改表的存储引擎(myisam<=>innodb)【转】

    修改表的存储引擎myisam<=>innodb 查看表的存储引擎mysql> show create table tt7;+-------+--------------------- ...

随机推荐

  1. robotframework之APP混合H5自动化测试

    app中有webview的情况 手机淘宝的天猫国际页面是一个webview robotframework代码: *** Settings *** Suite Setup Suite Teardown ...

  2. CentOS Linux自动备份MySQL数据库到远程FTP服务器并删除指定日期前的备份Shell脚本

    说明: 我这里要把MySQL数据库存放目录/var/lib/mysql下面的pw85数据库备份到/home/mysql_data里面,并且保存为mysqldata_bak_2011_11_03.tar ...

  3. git apply failed (转载)

    转自:http://blog.csdn.net/aaronzzq/article/details/6955893 git version 1.6.0.4 几个新手刚刚开始接触 Git,为了维护核心仓库 ...

  4. React 从入门到进阶之路(八)

    之前的文章我们介绍了 React中的组件.父子组件.React props父组件给子组件传值.子组件给父组件传值.父组件中通过refs获取子组件属性和方法.接下来我们将介绍 React propTyp ...

  5. Spring Cloud Alibaba基础教程:Sentinel Dashboard中修改规则同步到Nacos

    上一篇我们介绍了如何通过改造Sentinel Dashboard来实现修改规则之后自动同步到Apollo.下面通过这篇,详细介绍当使用Nacos作为配置中心之后,如何实现Sentinel Dashbo ...

  6. 洛谷 - P2055 - 假期的宿舍 - 最大流

    https://www.luogu.org/problemnew/show/P2055 这是一个错误的示范. 一开始觉得就找一条路从外校同学连到本校同学然后最终从周末回家的同学流出,每个人睡后一个人的 ...

  7. 洛谷 - P2578 - 九数码游戏 - bfs

    https://www.luogu.org/problemnew/show/P2578 一个挺搞的东西,用康托展开做记忆化搜索可以少一个log的查询. #include <bits/stdc++ ...

  8. Codeforces732E Sockets

    首先检测有木有和Computer匹配的Socket,如果有则将其匹配. 然后将所有没有匹配的Socket连上Adapter,再去检测有木有Computer与Socket匹配. 重复这个操作31次,所有 ...

  9. loj#2540. 「PKUWC2018」随机算法

    传送门 完了pkuwc咋全是dp怕是要爆零了-- 设\(f(S)\)表示\(S\)的排列数,\(S\)为不能再选的点集(也就是选到独立集里的点和与他们相邻的点),\(mx(S)\)表示\(S\)状态下 ...

  10. Beta版本冲刺第二天!

    该作业所属课程:https://edu.cnblogs.com/campus/xnsy/SoftwareEngineeringClass2 作业地址:https://edu.cnblogs.com/c ...