mysql中MyISAM引擎和Innodb引擎的区别

发布时间:2020-06-26 14:11:44 作者:Leah
来源:亿速云 阅读:192

今天就跟大家聊聊有关mysql中MyISAM引擎和Innodb引擎的区别,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

MyISAM引擎:

1、不支持事务

不支持事务,但是整个操作是原子性的(事务具备四种特性:原子性、一致性、隔离性、持久性)

2、不支持外键

不支持外键,支持表锁,每次所住的是整张表

MyISAM的表锁有读锁和写锁(两个锁都是表级别):

表共享读锁和表独占写锁。在对MyISAM表进行读操作时,不会阻塞其他用户对同一张表的读请求,但是会阻塞其他用户对表的写请求;对其进行写操作时会阻塞对同一表读操作和写操作

3、一个MyISAM表有三个文件

一个MyISAM表有三个文件:索引文件,表结构文件,数据文件

4、采用非聚集索引

采用非聚集索引,索引文件的数据域存储指向数据文件的指针。辅索引与主索引基本一致,但是辅索引不用保证唯一性。

Innodb引擎:

1、支持事务

支持事务,支持事务的四种隔离级别;是一种具有事务(commit)、回滚(rollback)和崩溃修复能力(crash recovery capabilities)的事务安全(transaction-safe (ACID compliant))型表。

2、支持行锁和外键约束

支持行锁和外键约束,因此可以支持写并发

3、一个Innodb表存储在一个文件内

一个Innodb表存储在一个文件内(共享表空间,表大小不受操作系统的限制),也可能为多个(设置为独立表空间,表大小受操作系统限制,大小为2G),受操作系统文件大小的限制

4、主键索引采用聚集索引

主键索引采用聚集索引(索引的数据域存储数据文件本身),辅索引的数据域存储主键的值;因此从辅索引查找数据,需要先通过辅索引找到主键值,再访问主键索引;最好使用自增主键,防止插入数据时,为维持B+树结构,文件的大调整。

看完上述内容,你们对mysql中MyISAM引擎和Innodb引擎的区别有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注亿速云行业资讯频道,感谢大家的支持。

推荐阅读:
  1. MySQL存储引擎MyISAM和InnoDB
  2. MySQL 储存引擎 MyISAM 和 InnoDB 配置

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

mysql myisam innodb

上一篇:python导出数据库数据的方法

下一篇:oracle11 r2版本卸载

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》