当前位置: 首页 > news >正文

Mysql InnoDB 存储引擎笔记

1 存储引擎 简介

Mysql 存储引擎有多种:包括 MyISAM、InnoDB 和 Memory。

其中MyISAM 和 INNODB 的区别:

  • 事务安全(MyISAM不支持事务,INNODB支持事务);
  • 外键 MyISAM 不支持外键, INNODB支持外键;
  • 锁机制(MyISAM时表锁,innodb是行锁);
  • 查询和添加速度(MyISAM批量插入速度快);
  • 支持全文索引(MyISAM支持全文索引,INNODB不支持全文索引);
  • MyISAM内存空间使用率比InnoDB低。

InnoDB是是最常用的存储引擎。

2 InnoDB 简介

存储引擎:是底层物理结构和实际文件读写的实现。
InnoDB 是一个将表中的数据存储到磁盘上的存储引擎。
InnoDB 的内存结构图如下:
在这里插入图片描述

3 InnoDB 三大特性

三大特性:

  1. 双写缓冲区
    Doublewrite buffer,
    作用:在把页写到数据文件之前,InnoDB 先把它们写到一个叫 doublewrite buffer(双写缓冲区)的连续区域内,在写 doublewrite buffer 完成后,InnoDB 才会把页写到数据文件的适当的位置。

  2. Buffer Pool
    处理客户端的请求时,当需要访问某个页的数据时,就会把完整的页的数据全部加载到内存中,将整个页加载到内存中后就可以进行读写访问了,在进行完读写访问之后并不着急把该页对应的内存空间释放掉,而是将其缓存起来,这样将来有请求再次访问该页面时,就可以省去磁盘 IO 的开销了。

  3. 自适应 Hash 索引
    InnoDB 去监控索引表,如果监控到某个索引经常用,那么就认为是热数据,然后内部自己创建一个 hash 索引,称之为自适应哈希索引(Adaptive Hash Index,AHI)。
    如果没有自适应 Hash 索引,需通过B+tree 索引中查询节点。

三大特性场景:
双写缓冲区:写磁盘;
Buffer Pool:读写缓存;
自适应 Hash 索引:查询数据。

小结
利用内存、磁盘(文件),应用不同数据结构(数组、链表、hash表、B+tree),处理读写数据的策略实现。

http://www.lryc.cn/news/26901.html

相关文章:

  • 智慧工地AI视频分析系统 opencv
  • 小红书「高效达人筛选攻略」
  • 大话数据结构-线性表
  • 分布式缓存 Memcached Linux 系统安装
  • 【数据结构】链表:看我如何顺藤摸瓜
  • linux shell 入门学习笔记18 函数开发
  • 如何最巧妙回答HR面试“送命题”:你为什么离开上家公司?
  • 注意力机制详解系列(五):分支与时间注意力机制
  • 创宇盾重保经验分享,看政府、央企如何防护?
  • 软件测试面试汇总
  • 空指针,野指针
  • Mysql Nested-Loop Join算法和MRR
  • Spark 广播/累加
  • 飞天云动,站在下一个商业时代的门口
  • 上海分时电价机制调整对储能项目的影响分析
  • 产品新人如何快速上手工作
  • Linux: ARM GIC仅中断CPU 0问题分析
  • 第20篇:Java运算符全面总结(系列二)
  • OpenCV4.x图像处理实例-OpenCV两小时快速入门(基于Python)
  • 【Git】Mac忽略.DS_Store文件
  • 12.2 基于Django的服务器信息查看应用(CPU信息)
  • 【软件测试】接口测试总结
  • 代码随想录算法训练营第52天 || 300.最长递增子序列 || 674. 最长连续递增序列 || 718. 最长重复子数组
  • gitblit 安装使用
  • 使用 TensorFlow、Keras-OCR 和 OpenCV 从技术图纸中获取信息
  • ESP32设备驱动-GUVA-S12SD紫外线检测传感器驱动
  • WIN7下 program file 权限不足?咋整?!!
  • 119.(leaflet篇)文字碰撞
  • cuda编程以及GPU基本知识
  • Python 机器学习/深度学习/算法专栏 - 导读目录