MySQL和InnoDB的关系不在这里介绍了.但是大家都知道其中相关的文件很多,类型很多.看文件名就有点分布清楚了.所以在这里简单介绍下他们的文件. 我们直接看文件列表以及在后面直接加注释.做笔记. [root@localhost mysql]# pwd/var/lib/mysql[root@localhost mysql]# [root@localhost mysql]# ll总用量 177320-rw-rw---- 1 mysql mysql 79691776 2月 28 15:30  ib…
构成MySQL数据库和InnoDB存储引擎表的各种类型文件,组要有以下文件 参数文件:告诉MySQL实例启动时在哪里可以找到,数据库文件,并且指定某些初始化参数,这些参数定义了某种内存结构的大小等设置 日志文件:用来记录MySQL实例对某种条件做出响应时写入的文件,如错误日志文件.二进制日志文件.慢查询日志文件.查询日志文件等 socket文件:当UNIX域套接字方式进行连接时需要的文件 pid文件:MySQL实例的进程ID文件 MySQL表结构文件:用来存放MySQL表结构定义文件 存储引擎文…
摘要:你知道吗,MySQL在实际工作时候的两种数据读写机制? 本文分享自华为云社区<MySQL日志顺序读写及数据文件随机读写原理>,作者:JavaEdge . MySQL在实际工作时候的两种数据读写机制: 对redo log.binlog这种日志进行的磁盘顺序读写 对表空间的磁盘文件里的数据页进行的磁盘随机读写 1 磁盘随机读 MySQL执行增删改操作时,先从表空间的磁盘文件里读数据页出来, 这就是磁盘随机读. 如下图有个磁盘文件,里面有很多数据页,可能需要在一个随机位置读取一个数据页到缓存,…
Myisam与innodb引擎,索引文件的区别: innodb的次索引指向对主键的引用. myisam的次索引和主索引都指向物理行. myisam一行一行的插入,会产生一行一行的文件,磁盘上有数据文件. tree树的值是磁盘上物理位置的指针. 比如加了主键索引,索引排成一棵树的形状.首先根据id=7在主键索引的树上查找,查找到7之后就知道了7所在的物理行,然后就可以找到id=7的那一行数据了. 还有一个cat_id索引,根据cat_id=15可以找到数据所在的物理行. 所以说myisam的次索引…
起因是这样的,公司的领导表示说服务器崩了,修理好之后,只剩下数据库目录下的物理文件(即.frm文件与.ibd文件).然后,整了一份压缩包给我,叫我瞅一下能不能把数据恢复出来.我当场愣了一下,这都啥文件啊,以前天天整开发,也没见到这种玩意啊.虽然对这文件不是很熟悉,但是领导交给我了,我也不能推脱,好歹要努力一下看看. 环境准备: 1.本文使用的是Windows 笔记本*1 ( 系统可以是Windows.也可以是CentOS.Debian等等MySQL Utilities能兼容的都行) 2.MySQ…
1.使用navicat fro mysql数据库工具进行恢复 2.将原有备份的sql文件导入数据库 3.新建一个空数据库 4将备份数据库的数据表复制到新建数据库(只复制表格式) 5.在命令行模式中 use 到新表 6.解除表空间 alter table 表名 discard tablespace; 7.将元数据data文件下的 表名.ibd文件复制到新数据库的data文件中 8.重新导入表空间 alter table 表名 import tablespace; 9.刷新数据表,数据还原成功.…
区别: 1. InnoDB支持事务,MyISAM不支持,对于InnoDB每一条SQL语言都默认封装成事务,自动提交,这样会影响速度,所以最好把多条SQL语言放在begin和commit之间,组成一个事务 2. InnoDB支持外键,而MyISAM不支持.对一个包含外键的InnoDB表转为MyISAM会失败 3. InnoDB是聚集索引,数据文件是和索引绑在一起的,必须要有主键,通过主键索引效率很高.但是辅助索引需要两次查询,先查询到主键,然后再通过主键查询到数据.因此,主键不应该过大,因为主键太…
InnoDB实现了两种类型的行锁. 共享锁(S):允许一个事务去读一行,阻止其他事务获得相同的数据集的排他锁. 排他锁(X):允许获得排他锁的事务更新数据,但是组织其他事务获得相同数据集的共享锁和排他锁. 简单来说 共享锁就是我读的时候,你可以读,但是不能写. 排他锁就是我写的时候,你即不能读也不能写. 除此之外InnoDB还有两个表锁: 意向共享锁(IS):表示事务准备给数据行加入共享锁,也就是说一个数据行加共享锁前必须先取得该表的IS锁 意向排他锁(IX):类似上面,表示事务准备给数据行加入…
记录通过.frm和.ibd文件恢复数据到本地 .frm文件:保存了每个表的元数据,包括表结构的定义等: .ibd文件:InnoDB引擎开启了独立表空间(my.ini中配置innodb_file_per_table = 1)产生的存放该表的数据和索引的文件. 以actclss表为例,结构如下 1.安装相同版本的mysql: 2.找回表结构(若有表结构,直接导入表即可) 建立同名的表(InnoDB),随意一个字段即可 关闭mysql服务,用需要恢复的.frm文件覆盖新生成的.frm文件.接着修改my…
InnoDB存储引擎文件 MySQL数据库包括数据库本身的文件和存储引擎文件.数据库自身的文件由参数文件(my.cnf).错误日志文件.慢查询日志文件.查询日志文件.二进制日志文件.套接字文件.pid文件.表结构定义文件(tabname.frm) 和InnoDB存储引擎相关的文件有表空间文件和重做日志文件. 一.表空间文件 InnoDB引擎将存储的数据按照表空间进行存放的设计.在默认配置下有一个初始大小10M,名为ibdata1的文件.该文件就是默认的表空间文件,可以通过innodb_data_…