数据库常用的两种引擎

InnoDB、MyISAM

两种引擎差异对比

如何选择引擎

select多,用MyISAM;

其他操作多,用InnoDB

两个引擎索引结构

查找mysql数据存储位置方式

  1. 找到mysql安装目录
  2. 打开my.ini
  3. 搜索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就是)

结构图如下:

两种引擎查找流程

  1. MyISAM
  2. InnoDB

B树和B+树的区别

B树的结构

索引两种类型

单值索引、联合索引

脏读、幻读、不可重复读

  1. 脏读

两个线程执行流程:

a线程将id=1的 字段1设置为10

b线程读取id=1的 字段1 数据 10

a线程对第一步操作进行回滚

b线程这时持有的 20 就是脏读

  1. 幻读

两个线程执行流程:

a线程读取用户id=1备注数量为一条

b线程将用户id=1备注添加了一条

a线程再次读取用户id=1备注数量,这时变成两条了

幻读又叫做幻行

  1. 不可重复度

两个线程执行流程:

a线程读取id=1的字段1数据为10

b线程将id=1的字段1数据修改为20

a线程再次读取id=1 字段1 ,发现两次读取的不一致,这就是不可重复读

四大隔离机制

读取未提交

可读取到未提交的数据,会导致脏读、幻读、不可重复读

读取已提交(Oracle 默认)

只读已提交的数据,会导致幻读、不可重复读

可重复读(mysql默认)

只读已提交的数据,但可读取多次,造成幻读

串行

并发差,不会造成脏读、幻读、不可重复读

Mysql引擎、隔离机制、存储结构、索引的更多相关文章

  1. 理解MySql事务隔离机制、锁以及各种锁协议

    一直以来对数据库的事务隔离机制的理解总是停留在表面,其内容也是看一遍忘一边.这两天决定从原理上理解它,整理成自己的知识.查阅资料的过程中发现好多零碎的概念假设串起来足够写一本书,所以在这里给自己梳理一 ...

  2. mysql的innodb数据存储结构

    ​ 数据库磁盘读取与系统磁盘读取 1,系统从磁盘中读取数据到内存时是以磁盘块(block)为基本单位,位于同一个磁盘块中的数据会被一次性读取出来. 2,innodb存储引擎中有页(Page)的概念,页 ...

  3. mysql innodb 的 逻辑存储结构

    如上图: innodb 的 逻辑存储单元分成 表空间,段,区,页 4个等级 默认情况下,一个数据库 所有变共享一个 默认的表空间(tablespan).可以指定每个表一个表空间. 一个表空间管理着 多 ...

  4. Mysql RR隔离更新列没有索引 会锁全表

    <pre name="code" class="html">mysql> show variables like '%tx_isolation ...

  5. MySQL两种表存储结构MyISAM和InnoDB的性能比较测试

    转载 http://www.jb51.net/article/5620.htm MySQL支持的两种主要表存储格式MyISAM,InnoDB,上个月做个项目时,先使用了InnoDB,结果速度特别慢,1 ...

  6. MySQL提升笔记(4)InnoDB存储结构

    这一节本来计划开始索引的学习,但是在InnoDB存储引擎的索引里,存在一些数据存储结构的概念,这一节先了解一下InnodDB的逻辑存储结构,为索引的学习打好基础. 从InnoDB存储引擎的存储结构看, ...

  7. MySQL InnoDB 逻辑存储结构

    MySQL InnoDB 逻辑存储结构 从InnoDB存储引擎的逻辑结构看,所有数据都被逻辑地存放在一个空间内,称为表空间,而表空间由段(sengment).区(extent).页(page)组成.p ...

  8. MYSQL Innodb逻辑存储结构

    转载于网络 这几天在读<MySQL技术内幕 InnoDB存储引擎>,对 Innodb逻辑存储结构有了些了解,顺便也记录一下: 从InnoDB存储引擎的逻辑存储结构看,所有数据都被逻辑地存放 ...

  9. 重新学习MySQL数据库3:Mysql存储引擎与数据存储原理

    重新学习Mysql数据库3:Mysql存储引擎与数据存储原理 数据库的定义 很多开发者在最开始时其实都对数据库有一个比较模糊的认识,觉得数据库就是一堆数据的集合,但是实际却比这复杂的多,数据库领域中有 ...

  10. InnoDB的表类型,逻辑存储结构,物理存储结构

    表类型 对比Oracle支持的各种表类型,InnoDB存储引擎表更像是Oracle中的索引组织表(index organized table).在InnoDB存储引擎表中,每张表都有个主键,如果在创建 ...

随机推荐

  1. JVM 问题分析思路

    1. 前言 工作中有可能遇到 java.lang.OutOfMemoryError: Java heap space 内存溢出异常, 本文提供一些内存溢出的分析及解决问题的思路. 常见异常如下: 20 ...

  2. 为什么C语言Scanf函数对字符串不要加 取地址运算符&

    原文1:http://www.360doc.com/content/16/0515/11/19455598_559288667.shtml 原文2:https://zhidao.baidu.com/q ...

  3. 基于Autolayout的动画

    在修改了约束之后,只要执行下面代码,就能做动画效果 [UIView animateWithDuration:1.0 animations:^{ [添加了约束的view的父控件 layoutIfNeed ...

  4. php程序员经验

    PHP 学习计划流程2008-10-22 17:23PHP 学习计划流程1.看教程 (2-3月)大概1天1个章节,比如<PHP圣经>有32章,1个多月就看完了,当然后面的章节每章1天肯定看 ...

  5. Collections与Arrays

    集合框架中的工具类:特点:该工具类中的方法都是静态的. Collections:常见方法: 1, 对list进行二分查找: 前提该集合一定要有序. int binarySearch(list,key) ...

  6. Centos 系统目录概述

    Linux目录一切从根目录开始,即"/",根下面的目录是一个有层次的树状结构.并且分区或磁盘是必须挂载在根目录才可以正常访问.做一个形象的比喻:目录类似一个一个的入口,而根目录则是 ...

  7. linux_4

    自建yum仓库,分别为网络源和本地源 编译安装http2.4 linux命令练习 列出ubuntu软件管理工具apt的一些用法(自由总结)

  8. 布尔值与比较运算符"=="

    $man = "男";$flag = $man == "男"; //双等号是比较运算符,返回布尔值,成立则返1赋给$flag 不成立返回0,0即为nullech ...

  9. Linux编译安装升级bash5.1

    线上服务器有次做漏洞扫描时,被扫描出有bash漏洞.平时还是比较少遇到有bash的漏洞,好在编译升级比较简单. 测试环境系统:CentOS.Ubuntu 一.下载官网最新bash版本 bash官网下载 ...

  10. Large Sacle Distributed Deep Networks

    本文是谷歌发表在NeurIPS 2012上的一篇论文,主要讨论了在几万个CPU节点上训练大规模深度网络的问题,并提出了一个名为DistBelief的软件框架.在该框架下实现了两种大规模分布式训练算法: ...