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存储引擎表中,每张表都有个主键,如果在创建 ...
随机推荐
- Codeforces Round #739 (Div. 3)
A. Dislike of Threes 简单的水题,预处理即可 AC_CODE #include <bits/stdc++.h> using namespace std; templat ...
- AOP自定义注解鉴权
刚出来工作那会或者在学校的时候,经常听到说AOP(面向对象编程,熟称切面)的用途是日志.鉴权等.但是那会不会,后面学会了,又没有写博客记录,今天写给大伙,希望能帮到大家 一.学习目标:利用AOP+自定 ...
- JVM垃圾收集器(八)
一.垃圾收集器 有了前面JVM参数的了解下面来看下JVM的垃圾收集器:如果说收集算法是内存回收的方法论,那么垃圾收集器就是内存回收的具体实现. JVM(HotSpot)有7种垃圾收集器,7种垃圾收集 ...
- PRML 基础知识
1 一个经典例子 一个经典的例子就是Polynomial Curve Fitting问题,现在将以此为基础介绍一些基本概念和方法.该问题的主要思路是针对给定的训练集\(\mathbf{x}\equ ...
- xss标签和属性爆破
当网站过滤了大部分的HTML标签和属性,我们就尝试爆破一下,看哪些标签和属性没有没过滤. 爆破的步骤: 1. 首先在测试点输入我们正常的exp,并抓包发送到Intruder模块. 2. 将exp改为 ...
- 总结tomcat的核心组件以及根目录结构
一.目录结构说明 进入到tomcat的文件目录,可以看到以下目录结构 每一个目录都有各自的功能,如下所示: 1.1 bin目录 1.2 conf目录 1.3 logs目录 二.核心组件 tomcat核 ...
- 如何写出优雅又地道的Python代码?【转载】
在Python社区文化的浇灌下,演化出了一种独特的代码风格,去指导如何正确地使用Python,这就是常说的pythonic.一般说地道(idiomatic)的python代码,就是指这份代码很pyth ...
- suse 12 二进制部署 Kubernetets 1.19.7 - 第04章 - 部署docker服务
文章目录 1.4.部署docker 1.4.0.下载docker二进制文件 1.4.1.配置docker镜像加速 1.4.2.配置docker为systemctl管理 1.4.3.启动docker服务 ...
- splunk设置索引周期和索引大小
步骤一: 编辑/opt/splunk/etc/apps/search/local/indexs.conf ,在每个索引下面 加入最后两行内容 [messages] coldPath = $SPLUNK ...
- 如何结合phpstorm配置在docker中的xdebug
作为一个资深的php开发者,我在之前的一篇文章里面也讲了如何搭建lnmp的docker镜像,这里不再赘述.在基于镜像运行容器中我也安装了xdebug,于是考虑用phpstorm来配置xdebug. 使 ...