Mysql引擎、隔离机制、存储结构、索引
数据库常用的两种引擎
InnoDB、MyISAM
两种引擎差异对比
如何选择引擎
select多,用MyISAM;
其他操作多,用InnoDB
两个引擎索引结构
查找mysql数据存储位置方式
- 找到mysql安装目录
- 打开my.ini
- 搜索datadir,就看到了
MyISAM
每张表都有三个文件
.frm 表结构文件,存放的是表结构信息
.MYD 数据文件,存放的是表数据及每行数据对应在磁盘中的地址
.MYI 索引文件 里面存放了设置的索引及与MYD文件相对应的磁盘地址
InnoDB
每张表都有.frm文件
而索引及索引数据有两种存储方式:
1. 非独立表空间
进入mysql安装目录,通过my.ini查找存储位置可发现idbdata1,
2. 独立表空间
每个表都对应有一个.idb文件
3. idb文件存的哪些内容
表的索引及索引对应行的数据都存放到这里了
4. 如何判断是否是独立表空间
判定条件除了上面看文件外,还可以通过执行sql查询
SHOW VARIABLES LIKE 'innodb_file_per_table';
value=off就代表是非独立表空间
聚簇索引&非聚簇索引
非聚簇索引:索引和索引数据存储在两个文件中(MyISAM就是)
结构图如下:
聚簇索引:索引和索引数据存储在一个文件中(InnoDB就是)
结构图如下:
两种引擎查找流程
- MyISAM
- InnoDB
B树和B+树的区别
B树的结构
索引两种类型
单值索引、联合索引
脏读、幻读、不可重复读
脏读
两个线程执行流程:
a线程将id=1的 字段1设置为10
b线程读取id=1的 字段1 数据 10
a线程对第一步操作进行回滚
b线程这时持有的 20 就是脏读
幻读
两个线程执行流程:
a线程读取用户id=1备注数量为一条
b线程将用户id=1备注添加了一条
a线程再次读取用户id=1备注数量,这时变成两条了
幻读又叫做幻行
不可重复度
两个线程执行流程:
a线程读取id=1的字段1数据为10
b线程将id=1的字段1数据修改为20
a线程再次读取id=1 字段1 ,发现两次读取的不一致,这就是不可重复读
四大隔离机制
读取未提交
可读取到未提交的数据,会导致脏读、幻读、不可重复读
读取已提交(Oracle 默认)
只读已提交的数据,会导致幻读、不可重复读
可重复读(mysql默认)
只读已提交的数据,但可读取多次,造成幻读
串行
并发差,不会造成脏读、幻读、不可重复读
Mysql引擎、隔离机制、存储结构、索引的更多相关文章
- 理解MySql事务隔离机制、锁以及各种锁协议
一直以来对数据库的事务隔离机制的理解总是停留在表面,其内容也是看一遍忘一边.这两天决定从原理上理解它,整理成自己的知识.查阅资料的过程中发现好多零碎的概念假设串起来足够写一本书,所以在这里给自己梳理一 ...
- mysql的innodb数据存储结构
数据库磁盘读取与系统磁盘读取 1,系统从磁盘中读取数据到内存时是以磁盘块(block)为基本单位,位于同一个磁盘块中的数据会被一次性读取出来. 2,innodb存储引擎中有页(Page)的概念,页 ...
- mysql innodb 的 逻辑存储结构
如上图: innodb 的 逻辑存储单元分成 表空间,段,区,页 4个等级 默认情况下,一个数据库 所有变共享一个 默认的表空间(tablespan).可以指定每个表一个表空间. 一个表空间管理着 多 ...
- Mysql RR隔离更新列没有索引 会锁全表
<pre name="code" class="html">mysql> show variables like '%tx_isolation ...
- MySQL两种表存储结构MyISAM和InnoDB的性能比较测试
转载 http://www.jb51.net/article/5620.htm MySQL支持的两种主要表存储格式MyISAM,InnoDB,上个月做个项目时,先使用了InnoDB,结果速度特别慢,1 ...
- MySQL提升笔记(4)InnoDB存储结构
这一节本来计划开始索引的学习,但是在InnoDB存储引擎的索引里,存在一些数据存储结构的概念,这一节先了解一下InnodDB的逻辑存储结构,为索引的学习打好基础. 从InnoDB存储引擎的存储结构看, ...
- MySQL InnoDB 逻辑存储结构
MySQL InnoDB 逻辑存储结构 从InnoDB存储引擎的逻辑结构看,所有数据都被逻辑地存放在一个空间内,称为表空间,而表空间由段(sengment).区(extent).页(page)组成.p ...
- MYSQL Innodb逻辑存储结构
转载于网络 这几天在读<MySQL技术内幕 InnoDB存储引擎>,对 Innodb逻辑存储结构有了些了解,顺便也记录一下: 从InnoDB存储引擎的逻辑存储结构看,所有数据都被逻辑地存放 ...
- 重新学习MySQL数据库3:Mysql存储引擎与数据存储原理
重新学习Mysql数据库3:Mysql存储引擎与数据存储原理 数据库的定义 很多开发者在最开始时其实都对数据库有一个比较模糊的认识,觉得数据库就是一堆数据的集合,但是实际却比这复杂的多,数据库领域中有 ...
- InnoDB的表类型,逻辑存储结构,物理存储结构
表类型 对比Oracle支持的各种表类型,InnoDB存储引擎表更像是Oracle中的索引组织表(index organized table).在InnoDB存储引擎表中,每张表都有个主键,如果在创建 ...
随机推荐
- React Transition css动画案例解析
实现React Transition Css动画效果 首先在项目工程中引入react-transition-group: npm install react-transition-group --sa ...
- new JSONObject 无异常卡顿【Maven+Idea 导包不更新的小坑】
问题描述 今天在使用JSONObject过程中出现了一个非常不可思议的现象,我Junit测试没有问题,但是就是打开服务器运行的时候,结果就是出不来,经过多次测试发现代码竟然卡在了new JSONObj ...
- 使用@WebServlet等注解需要i注意的
Servlet 3.0 的部署描述文件 web.xml 的顶层标签 <web-app> 有一个 metadata-complete 属性,该属性指定当前的部署描述文件是否是完全的.如果设置 ...
- HOOK API(二) —— HOOK自己程序的 MessageBox
转载来源:https://www.cnblogs.com/hookjc/ 0x00 前言 以下将给出一个简单的例子,作为HOOK API的入门.这里是HOOK 自己程序的MessageBox,即将自己 ...
- git 撤销,放弃本地修改,放弃已提交修改
一, 未使用 git add 缓存代码时. 可以使用 git checkout -- filepathname (比如: git checkout -- readme.md ,不要忘记中间的 &quo ...
- Scala变量和数据类型
一.注释及代码规范 Scala的注释和Java中完全相同:单行注释:// .多行注释:/* */ 以及文档注释:/** */: 使用tab操作,实现缩进,默认整体向右边移动,用shift+tab整 ...
- web测试学习大纲
Web测试 Web测试体系介绍 网络协议 Web开发 基础 原理 前端分析 安全性测试 可用性,兼容性 功能测试(同系统测试) 理解网络协议 互联网历史沿革 Web系统基础 Web核心技术 web服务 ...
- Lesson11——NumPy 位运算
NumPy 教程目录 Lesson11--NumPy 位运算 NumPy "bitwise_" 开头的函数是位运算函数. NumPy 位运算包括以下几个函数: 函数 描述 bitw ...
- 2、网络并发编程--套接字编程、黏包问题、struct模块、制作简易报头、上传文件数据
昨日内容回顾 面向对象复习(json序列化类) 对象.类.父类的概念 三大特性:封装 继承 多态 双下开头的方法(达到某个条件自动触发) __init__:对象实例化自动触发 __str__:对象执行 ...
- Asp-Net-Core开发笔记:使用NPM和gulp管理前端静态文件
前言 本文介绍的是AspNetCore的MVC项目,WebApi+独立前端这种前后端分离的项目就不需要多此一举了~默认前端小伙伴是懂得使用前端工具链的. 为啥要用MVC这种服务端渲染技术呢? 简单项目 ...