• 技术文章 >数据库 >MySQL

    mysql存储引擎的区别有哪些

    尤及尤及2020-06-17 13:58:34原创2424

    mysql存储引擎的区别:

    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+树结构,文件的大调整。

    更多Python知识,请关注:Python自学网!!

    专题推荐:mysql
    上一篇:mysql无法登录怎么办 下一篇:mysql主从不同步怎么办

    相关文章推荐

    • mysql in or 区别• centos 下载哪个mysql• mysql不等于查询语句怎么写• mysql如何查询不同的数据• mysql字段不为空查询语句如何写• mysql并怎么表示• 如何解决mysql不是内部命令的错误

    全部评论我要评论

    © 2021 Python学习网 苏ICP备2021003149号-1

  • 取消发布评论
  • 

    Python学习网