专业编程基础技术教程

网站首页 > 基础教程 正文

mysql-innodb和myisam存储引擎 mysql的两种存储引擎区别,各自的使用场景

ccvgpt 2024-10-12 14:02:35 基础教程 9 ℃

查看mysql版本

查看mysql支持的存储引擎

SHOW ENGINES;


mysql-innodb和myisam存储引擎 mysql的两种存储引擎区别,各自的使用场景


MyISAM与InnoBD对比


MyISAM

InnoDB

存储结构

Mysql8以前是.frm,之后被.sdi替换掉

每个MyISAM在磁盘上存储成三个文件。第一个文件的名字以表的名字开始,扩展名指出文件类型。
.frm/.sdi文件存储表定义;
数据文件的扩展名为.MYD (MYData);
索引文件的扩展名是.MYI (MYIndex);

.idb 结构、索引和数据;

事务

不提供事务支持

支持事务,回滚,对于有update ,delete操作的表,效率更好

UPDATE,INSERT,Delete操作

如果执行大量的SELECT,MyISAM是更好的选择

1.如果你的数据执行大量的INSERT或UPDATE,出于性能方面的考虑,应该使用InnoDB表;
2.DELETE FROM table时,InnoDB不会重新建立表,而是一行一行的删除;

对AUTO_INCREMENT的操作

每表一个AUTO_INCREMEN列的内部处理。
MyISAM为INSERT和UPDATE操作自动更新这一列。这使得AUTO_INCREMENT列更快(至少10%)。在序列顶的值被删除之后就不能再利用。(当AUTO_INCREMENT列被定义为多列索引的最后一列,可以出现重使用从序列顶部删除的值的情况)。
AUTO_INCREMENT值可用ALTER TABLE或myisamch来重置
对于AUTO_INCREMENT类型的字段,InnoDB中必须包含只有该字段的索引,但是在MyISAM表中,可以和其他字段一起建立联合索引
更好和更快的auto_increment处理

如果你为一个表指定AUTO_INCREMENT列,在数据词典里的InnoDB表句柄包含一个名为自动增长计数器的计数器,它被用在为该列赋新值;
自动增长计数器仅被存储在主内存中,而不是存在磁盘上;

表的具体行数

select count(*) from table,MyISAM只要简单的读出保存好的行数,注意的是,当count(*)语句包含 where条件时,两种表的操作是一样的

InnoDB 中不保存表的具体行数,也就是说,执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行

表锁

提供行锁(locking on row level),提供与 Oracle 类型一致的不加锁读取(non-locking read in
SELECTs),

另外,InnoDB表的行锁也不是绝对的,如果在执行一个SQL语句时MySQL不能确定要扫描的范围,InnoDB表同样会锁全表, 例如update table set num=1 where name like "%aaa%"

索引

索引都不是聚簇索引,在查询时至少需要进行一次的回表查询,其执行的过程:先通过索引表查询到索引对应该行的物理地址,然后去读该物理地址的值

主键索引就是聚簇索引(叶子节点会存储数据行),通过主键索引效率很高。但是辅助索引需要两次查询,先查询到主键,然后再通过主键查询到数据。因此,主键不应该过大,因为主键太大,其他索引也都会很大

主键

可以没有,不支持外键

每张表默认都需要主键;

容灾恢复

不支持

a.Innodb 内存结构中有log buffer,当有更新的时候,先写入log,并更新到内存,innodb会在空闲的时候更新磁盘。有了 redo log(是 InnoDB 引擎特有的),InnoDB 就可以保证即使数据库发生异常重启,之前提交的记录都不会丢失,这个能力称为 crash-safe。
redo log 是物理日志,记录的是“在某个数据页上做了什么修改”;

bin log 是逻辑日志,记录的是这个语句的原始逻辑,比如“给 ID=2 这一行的 c 字段加 1 ”。

全表行数

有存储,变量存储

无存储

存储结构

win系统安装的mysql,文件示例如下

student是innodb,student_data是myisamdb

MySQL 存储引擎 MyISAM 与 InnoDB 如何选择?

虽然 MySQL 里的存储引擎不只是 MyISAM 与 InnoDB 这两个,但常用的就是它俩了。可能有站长并未注意过 MySQL 的存储引擎,其实存储引擎也是数据库设计里的一大重要点,那么博客系统应该使用哪种存储引擎呢?

下面我们分别来看两种存储引擎的区别。

一、InnoDB支持事务,MyISAM不支持,这一点是非常之重要。事务是一种高级的处理方式,如在一些列增删改中只要哪个出错还可以回滚还原,而MyISAM就不可以了;

二、MyISAM适合查询以及插入为主的应用,InnoDB适合频繁修改以及涉及到安全性较高的应用;

三、InnoDB支持外键,MyISAM不支持;

四、MySQL 在 5.1 之前版本默认存储引擎是 MyISAM,5.1 之后版本默认存储引擎是 InnoDB;

五、InnoDB不支持FULLTEXT类型的索引;

六、InnoDB中不保存表的行数,如select count(*) from table时,InnoDB需要扫描一遍整个表来计算有多少行,但是MyISAM只要简单的读出保存好的行数即可。注意的是,当count(*)语句包含where条件时MyISAM也需要扫描整个表;

七、对于自增长的字段,InnoDB中必须包含只有该字段的索引,但是在MyISAM表中可以和其他字段一起建立联合索引;

八、清空整个表时,InnoDB是一行一行的删除,效率非常慢。MyISAM则会重建表;

九、InnoDB支持行锁(某些情况下还是锁整表,如 update table set a=1 where user like '%lee%';

注意:innodb与myisamdb创建的表,可以关联查询哦~。

最近发表
标签列表