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

相关文章

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据