Mysql的【存储引擎】之【InnoDB】与【MyISAM】的区别

2024-04-21 15:36

本文主要是介绍Mysql的【存储引擎】之【InnoDB】与【MyISAM】的区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1.存储引擎在 MyISAM 和 InnoDB 有什么区别

2.Mysql 5.7 默认的存储引擎是什么

3.一个简单例子(如果非要使用【MyISAM】存储引擎 )

4.2009年写的留言板程序的数据(存储引擎是:【MyISAM】)

5.mysql 8.0 可以使用 MyISAM 存储引擎 吗?

6.什么是【InnoDB】数据库引擎

7.什么是【MyISAM】数据库引擎

8.ISAM 和 InnoDB 相比,有什么优势


-----------

1.存储引擎在 MyISAM 和 InnoDB 有什么区别

MyISAM 和 InnoDB 是 MySQL 中两种常用的存储引擎,它们有以下区别:

  1. 事务支持:InnoDB 支持事务,可以使用 COMMIT 和 ROLLBACK 来实现事务的原子性、一致性、隔离性和持久性,而 MyISAM 不支持事务。

  2. 行级锁和表级锁:InnoDB 支持行级锁,可以提高多用户并发时的性能,而 MyISAM 只支持表级锁,在并发访问下可能会导致性能问题。

  3. 外键约束:InnoDB 支持外键约束,可以保证数据的完整性和一致性,而 MyISAM 不支持外键约束。

  4. 数据缓存:InnoDB 会缓存数据和索引,可通过缓冲池来提升性能,而 MyISAM 只缓存索引,不缓存数据,对于频繁读取的应用可能会有些许性能上的差异。

  5. 崩溃恢复:InnoDB 在MySQL异常情况下更加稳健,其崩溃恢复能力较强。而MyISAM在某些情况下可能会出现数据丢失。

基于以上区别,一般来说,对于需要支持事务、需要较好并发控制和数据完整性的应用,推荐使用 InnoDB 存储引擎;而对于仅需要快速读取、对数据完整性要求不高的应用,可以考虑使用 MyISAM 存储引擎。

2.Mysql 5.7 默认的存储引擎是什么

Mysql 5.7 默认的存储引擎是 InnoDB。从Mysql 5.5版本开始,InnoDB 被作为默认的存储引擎,并取代了之前的 MyISAM。这是因为 InnoDB 支持事务、行级锁和外键约束等特性,适合更多的应用场景,提供了更好的性能和数据完整性。

3.一个简单例子(如果非要使用【MyISAM】存储引擎 )

create database messageBoard DEFAULT CHARACTER SET utf8;

create database messageBoard DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;

-------

create table messageboard_user(
   id int not null auto_increment primary key,
   muId varchar(16) NOT NULL,
   muMessage varchar(100) NOT NULL,
   muReply varchar(100),
   muTime TIMESTAMP NOT NULL,
   muState varchar(15),
   muIp varchar(20) NOT NULL
)Engine=MyISAM
DEFAULT CHARACTER SET utf8;

4.2009年写的留言板程序的数据(存储引擎是:【MyISAM】)

===

MySQL数据库连接配置(tomcat,java)_tomcat maxwaitmillis-CSDN博客

===

5.mysql 8.0 可以使用 MyISAM 存储引擎 吗?

是的,MySQL 8.0 仍然支持 MyISAM 存储引擎。尽管在 MySQL 5.5 版本及之后,InnoDB 被设置为默认存储引擎,但是 MyISAM 仍然可以在 MySQL 8.0 中使用。然而,MySQL 官方建议将表格转换为 InnoDB 存储引擎以获得更好的性能和数据完整性。 MyISAM 存储引擎在某些情况下仍然有其特定的用途,比如进行只读操作或者非事务性的简单存储等情况。

==

6.什么是【InnoDB】数据库引擎

"InnoDB"是一种数据库存储引擎,最初由Innobase Oy公司开发,后来被MySQL AB公司收购。这个名称确实不是一个显而易见的缩写或全称,但"Inn"可能代表"inner"(内部)的一个缩写,"DB"代表数据库。因此,可以将"InnoDB"解释为一种内部支持数据库操作的存储引擎。希望这次的解释更清楚了。如果您还有任何疑问,请随时告诉我。

--

Innobase Oy是一家位于芬兰赫尔辛基的数据库技术公司,最初开发了InnoDB存储引擎。公司成立于1995年,专注于开发高性能的数据库管理系统技术。在2005年,Innobase Oy被MySQL AB收购,后来MySQL AB被Sun Microsystems和Oracle收购。InnoDB存储引擎被MySQL数据库广泛应用。

===

7.什么是【MyISAM】数据库引擎

MyISAM存储引擎是MySQL数据库系统的另一种存储引擎,最初由Uppsala University数据库研究组开发。MyISAM最早出现在MySQL 3.23版本中,并在之后的MySQL版本中得到持续改进和优化。MyISAM存储引擎以其简单、快速和高效的特性而闻名,是MySQL数据库中最常用的存储引擎之一。

MyISAM存储引擎具有以下特点:

  1. 支持全文本索引:MyISAM存储引擎提供了全文本索引的支持,使得用户可以进行高效的全文搜索操作。
  2. 不支持事务和外键约束:相比InnoDB存储引擎,MyISAM不支持事务处理和外键约束,因此在需要事务支持和数据完整性方面可能不如InnoDB存储引擎。
  3. 表级锁定:MyISAM采用表级锁定,因此在高并发的情况下可能出现锁定竞争,影响系统性能。

总的来说,MyISAM存储引擎适用于读写不频繁且对数据完整性要求不高的场景,例如用于存储静态数据或日志信息。如果您有任何其他问题或需要更多详细信息,请随时告诉我。

---

ISAM是指Indexed Sequential Access Method(索引顺序存取方法),是一种早期的数据库存储引擎技术,主要用于将数据按照顺序排列,并使用索引进行快速检索。ISAM将数据存储在一个主数据文件和一个索引文件中,通过索引来加快数据检索速度。然而,ISAM不支持事务处理和并发访问控制,因此在现代数据库系统中已经较少使用。MySQL数据库中没有ISAM存储引擎,但InnoDB存储引擎就是一个常用的替代选择,它支持事务处理和具有更好的并发性能。

==

8.ISAM 和 InnoDB 相比,有什么优势

ISAM和InnoDB是两种不同的存储引擎技术,它们各自有着不同的优势和劣势。

优势:

ISAM的优势:

  • ISAM拥有简单架构,因此对资源消耗较小,读取速度较快。
  • ISAM适用于静态或者少量变动的数据,需要定期维护索引,但在某些特定场景下可以有较好的性能表现。
  • InnoDB的优势:
  • InnoDB支持事务处理和行级锁定,保证数据的完整性和一致性,更适合于有较高并发要求的应用。
  • InnoDB支持外键约束和更多的数据恢复和备份功能,更适合于需要强大数据库功能和可靠性的应用场景。
  • InnoDB适合于大规模数据存储和频繁更新的场景,具有更好的性能和稳定性。

总的来说,InnoDB在事务处理、数据完整性、大规模数据处理等方面有着明显的优势,而ISAM适用于一些小型或者特定场景下的应用。在选择存储引擎时,需要根据具体的应用需求来选择合适的存储引擎。

---

这篇关于Mysql的【存储引擎】之【InnoDB】与【MyISAM】的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/923429

相关文章

SpringBoot3.X 整合 MinIO 存储原生方案

《SpringBoot3.X整合MinIO存储原生方案》本文详细介绍了SpringBoot3.X整合MinIO的原生方案,从环境搭建到核心功能实现,涵盖了文件上传、下载、删除等常用操作,并补充了... 目录SpringBoot3.X整合MinIO存储原生方案:从环境搭建到实战开发一、前言:为什么选择MinI

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

MyBatis中$与#的区别解析

《MyBatis中$与#的区别解析》文章浏览阅读314次,点赞4次,收藏6次。MyBatis使用#{}作为参数占位符时,会创建预处理语句(PreparedStatement),并将参数值作为预处理语句... 目录一、介绍二、sql注入风险实例一、介绍#(井号):MyBATis使用#{}作为参数占位符时,会

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

浅谈mysql的not exists走不走索引

《浅谈mysql的notexists走不走索引》在MySQL中,​NOTEXISTS子句是否使用索引取决于子查询中关联字段是否建立了合适的索引,下面就来介绍一下mysql的notexists走不走索... 在mysql中,​NOT EXISTS子句是否使用索引取决于子查询中关联字段是否建立了合适的索引。以下

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Javaee多线程之进程和线程之间的区别和联系(最新整理)

《Javaee多线程之进程和线程之间的区别和联系(最新整理)》进程是资源分配单位,线程是调度执行单位,共享资源更高效,创建线程五种方式:继承Thread、Runnable接口、匿名类、lambda,r... 目录进程和线程进程线程进程和线程的区别创建线程的五种写法继承Thread,重写run实现Runnab