00-MySQL存储引擎

1.InnoDB

1.1 innodb存储引擎的mysql表提供了事务,回滚以及系统崩溃修复能力和多版本迸发控制的事务的安全
1.2 innodb支持自增长列(auto_increment),自增长列的值不能为空,如果在使用的时候为空的话怎会进行自动存现有的值开始增值,如果有但是比现在的还大,则就保存这个值
1.3 innodb存储引擎支持外键(foreign key) ,外键所在的表称为子表而所依赖的表称为父表
1.4 innodb存储引擎最重要的是支持事务,以及事务相关联功能
1.5 innodb采用mvcc支持高并发,并且实现了4个标准的隔离级别,默认可重复读,并且通过间隙锁策略放置幻读的出现(间隙锁使得innodb不仅仅锁定查询涉及到的行,还会对索引中的间隙进行锁定,以防止幻影行的插入)
1.6 innodb存储引擎索引使用的是B+Tree


2.MyISAM引擎

2.1 不支持事务,不支持行级锁,只支持并发插入的表锁,主要用于高负载的select
2.2 支持三种不同的存储结构:静态型、动态型、压缩型。

2.2.1静态型:就是定义的表列的大小是固定(即不含有:xblob、xtext、varchar等长度可变的数据类型),这样mysql就会自动使用静态myisam格式。使用静态格式的表的性能比较高,因为在维护和访问的时候以预定格式存储数据时需要的开销很低。但是这高性能是有空间换来的,因为在定义的时候是固定的,所以不管列中的值有多大,都会以最大值为准,占据了整个空间。
2.2.2 动态型:如果列(即使只有一列)定义为动态的(xblob, xtext, varchar等数据类型),这时myisam就自动使用动态型,虽然动态型的表占用了比静态型表较少的空间,但带来了性能的降低,因为如果某个字段的内容发生改变则其位置很可能需要移动,这样就会导致碎片的产生。随着数据变化的怎多,碎片就会增加,数据访问性能就会相应的降低。
2.2.3 压缩型:如果在这个数据库中创建的是在整个生命周期内只读的表,则这种情况就是用myisam的压缩型表来减少空间的占用。


3.MEMORY引擎

3.1MEMORY存储引擎提供“内存”表, 也不支持事务、 外键
3.2磁盘文件只存储表结构,数据都存储在内存中。
3.3存储引擎默认使用哈希(HASH)索引,其速度比使用B-+Tree型要快,如果读者希望使用B树型,则在创建的时候可以引用。
3.4文件数据都存储在内存中,如果mysqld进程发生异常,重启或关闭机器这些数据都会消失。所以memory存储引擎中的表的生命周期很短,一般只使用一次


4.BlackHole存储引擎

4.1支持事务,而且支持mvcc的行级锁,主要用于日志记录或同步归档,这个存储引擎除非有特别目的,否则不适合使用!


5.存储引擎选择

5.1是否需要事务支持

5.2是否为高并发, InnoDB实现了行锁, 这方面的表现大大优于MyISAM

5.3索引, 不同存储引擎的索引实现不尽相同

5.4是否需要外键

5.5高效缓冲数据, InnoDB缓冲数据而MyISAM只缓冲了索引

5.6备份, 是否需要支持热备份


6.概念讲解

6.1 事务ACID 特性

原子性,一致性,隔离性,持久性

6.2 事务的隔离级别

read uncommitted(未提交读)

在该级别中,事务中的修改,及时没有提交,对其他事务也是可见的。事务可以读取未提交的数据,也成为 dirty read

read committed(提交读)

一个事务开始时,只能看见已提交的事务所做出的修改(一个事务从开始直到提交之前,所做的任何修改对其他事务都是不可见的,因此也叫做不可重复读,因为两次执行同样的查询,可能得到的不同的结果)

repeatable read(可重复读)

解决 dirty read的问题,该级别保证了在同一个事务中多次读取同样记录的结果是一致的,但无法解决换读的问题,所谓幻读指当前某个事务在独立某个范围内的记录时,另一个事务又在该范围内插入了新记录。innodb通过 引入mvcc解决了幻读的问题

seriablizable(可串行化)

最高的隔离级别,强制事务串行执行,避免幻读问题。在读取的每一行上加锁,可能导致大量的超时和锁竞争的问题,实际中很少用。

6.2 mvcc

多版本并发控制

mvcc是行锁的变种,但是他在很多情况下避免了加锁操作,因此开销更低。大多实现了非阻塞的读操作,写操作也只锁定必要的行mvcc的实现是通过保存数据在某个时间点的快照来实现的,也就是说,不管需要执行多长时间,每个事务看到的数据都是一致的,根据事务开始的时间不同,每个事务对同一张表,同一时刻看到的数据可能是不一样的

innodb的mvcc是通过在每行记录后面保存两个隐藏的列来实现的。这两个列,一个保存了行创建的时间,一个保存行的过期时间/删除时间。当然存储的并不是实际的时间值,而是系统版本号。每开始一个新的事务,系统版本号就会自动递增。事务开始时刻的系统版本号会作为事务的版本号,用来和查询到的每行记录的版本号进行比较。


image.png

保存的两个额外的系统版本号,使大多数读操作都可以不用加锁,该设计使得读数据操作很简单,性能很好,不足之处就是需要额外的空间,需要做更多的检查工作,以及一些额外的维护工作。

6.3 数据库锁

锁对主要作用是管理共享资源的并发访问,用于实现事务的隔离性

锁类型

读锁(共享锁)
写锁(独占锁)

死锁

事务间的循环依赖导致死锁发生,innodb通过检测循环依赖来检测死锁,并且将最少行级排他锁的事务进行回滚

MySQL锁的粒度

表级锁(开销小,并发性低),通常在服务器层实现
行级锁(开销大,并发性高),只会在存储引擎层面进行实现

隐式和显式锁定

InnoDB采用的式两阶段锁定协议。在事务执行过程中,随时都可以执行锁定,锁只有在执行 commit / rollback 时才会释放,并且所有的锁是同一时刻释放

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,377评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,390评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,967评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,344评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,441评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,492评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,497评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,274评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,732评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,008评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,184评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,837评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,520评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,156评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,407评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,056评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,074评论 2 352

推荐阅读更多精彩内容