MySQL常用存储引擎的分析

本篇文章给大家带来的内容是关于mysql常用存储引擎的分析,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

MyISAM:每个MyISAM在磁盘上存储成三个文件。第一个文件的名字以表的名字开始,扩展名指出文件类型。.frm文件存储表定义。数据文件的扩展名为.MYD

(MYData)。索引文件的扩展名是.MYI (MYIndex)。

MyISAM是MySQL的默认数据库引擎(5.5版之前),由早期的ISAM(Indexed Sequential Access Method:有索引的顺序访问方法)所改良。虽然性能极佳,但却有一个缺点:不支持事务处理(transaction)。

InnoDB是MySQL的数据库引擎之一,为MySQL AB发布binary的标准之一。与传统的ISAM与MyISAM相比,InnoDB的最大特色就是:支持事务(Transaction)。

MyISAM与InnoDB的区别是什么?总结如下:

1、 存储结构

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

InnoDB:所有的表都保存在同一个数据文件中(也可能是多个文件,或者是独立的表空间文件),InnoDB表的大小只受限于操作系统文件的大小,一般为2GB。

2、 存储空间

MyISAM:可被压缩,存储空间较小。支持三种不同的存储格式:静态表(默认,但是注意数据末尾不能有空格,会被去掉)、动态表、压缩表。

InnoDB:需要更多的内存和存储,它会在主内存中建立其专用的缓冲池用于高速缓冲数据和索引。

3、 可移植性、备份及恢复

MyISAM:数据是以文件的形式存储,所以在跨平台的数据转移中会很方便。在备份和恢复时可单独针对某个表进行操作。

InnoDB:免费的方案可以是拷贝数据文件、备份 binlog,或者用 mysqldump,在数据量达到几十G的时候就相对痛苦了。

4、 事务支持

MyISAM:强调的是性能,每次查询具有原子性,其执行数度比InnoDB类型更快,但是不提供事务支持。

InnoDB:提供事务支持事务,外部键等高级数据库功能。 具有事务(commit)、回滚(rollback)和崩溃修复能力(crash recovery capabilities)的事务安全(transaction-safe (ACID compliant))型表。

5、 AUTO_INCREMENT

MyISAM:可以和其他字段一起建立联合索引。引擎的自动增长列必须是索引,如果是组合索引,自动增长可以不是第一列,他可以根据前面几列进行排序后递增。

InnoDB:InnoDB中必须包含只有该字段的索引。引擎的自动增长列必须是索引,如果是组合索引也必须是组合索引的第一列。

6、 表锁差异

卡奥斯智能交互引擎 卡奥斯智能交互引擎

聚焦工业领域的AI搜索引擎工具

卡奥斯智能交互引擎 36 查看详情 卡奥斯智能交互引擎

MyISAM:只支持表级锁,用户在操作myisam表时,select,update,delete,insert语句都会给表自动加锁,如果加锁以后的表满足insert并发的情况下,可以在表的尾部插入新的数据。

InnoDB:支持事务和行级锁,是innodb的最大特色。行锁大幅度提高了多用户并发操作的新能。但是InnoDB的行锁,只是在WHERE的主键是有效的,非主键的WHERE都会锁全表的。

7、 全文索引

MyISAM:支持 FULLTEXT类型的全文索引

InnoDB:不支持FULLTEXT类型的全文索引,但是innodb可以使用sphinx插件支持全文索引,并且效果更好。

8、 表主键

MyISAM:允许没有任何索引和主键的表存在,索引都是保存行的地址。

InnoDB:如果没有设定主键或者非空唯一索引,就会自动生成一个6字节的主键(用户不可见),数据是主索引的一部分,附加索引保存的是主索引的值。

9、 表的具体行数

MyISAM:保存有表的总行数,如果select count() from table;会直接取出出该值。

InnoDB:没有保存表的总行数,如果使用select count() from table;就会遍历整个表,消耗相当大,但是在加了wehre条件后,myisam和innodb处理的方式都一样。

10、 CURD操作

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

InnoDB:如果你的数据执行大量的INSERT或UPDATE,出于性能方面的考虑,应该使用InnoDB表。DELETE 从性能上InnoDB更优,但DELETE FROM table时,InnoDB不会重新建立表,而是一行一行的删除,在innodb上如果要清空保存有大量数据的表,最好使用truncate table这个命令。

11、 外键

MyISAM:不支持

InnoDB:支持

通过上述的分析,基本上可以考虑使用InnoDB来替代MyISAM引擎了,但是在实际的应用中,具体情况可以自己斟酌。

以上就是MySQL常用存储引擎的分析的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/380392.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月6日 11:07:13
下一篇 2025年11月6日 11:08:17

相关推荐

  • 从产品经理到独立开发人员:六个月转型指南

    从零基础到独立开发者:我的四个月转型之路 想在短短几个月内从零经验转型为能获得付费工作的独立开发者?这确实充满挑战。我曾是一名新手,甚至可以说是“菜鸟”,但我的经历证明,一切皆有可能。本文分享我的故事,希望能激励那些面临同样困境的人。 独立开发需要全面的技能。我之前的产品经理背景让我对开发流程和技术…

    2025年12月11日 好文分享
    000
  • PHP7各个版本的兼容性如何

    理论上,PHP7版本向下兼容,但实际升级可能存在细微改动导致行为差异。理解兼容性需了解PHP版本命名规则、变更日志,以及Zend引擎演进。向下兼容性仅指新版本运行旧代码,但行为可能不一致。弃用函数、扩展库不兼容是常见兼容性问题。进行全面兼容性测试至关重要,以避免上线问题。升级PHP版本可带来性能提升…

    2025年12月11日
    000
  • PHP 8如何防止代码注入攻击

    PHP 8 防止代码注入攻击的核心方法是:不相信用户输入,将其视为潜在的恶意输入。使用参数化查询和预编译语句,将用户输入作为数据传递,避免被解释为代码执行。进行输入验证和过滤,检查数据类型、长度和格式,确保符合预期。通过代码审查、调试和性能优化,确保代码正确性、效率和可维护性。 PHP 8 如何有效…

    2025年12月11日
    000
  • PHP 8如何进行错误和异常处理

    PHP 8 引入了更强大的错误和异常处理机制,包括:增强异常处理,使用 try…catch 语句块捕获和处理异常。自定义异常类,创建更具表达力的错误处理系统。性能考量和最佳实践,在需要特殊处理的情况下使用异常,避免过度使用。 PHP 8 的优雅错误与异常处理:不止是try…catch…

    2025年12月11日
    000
  • PHP 8如何防范SQL注入

    PHP 8 提供了多个防御 SQL 注入的方法:参数化查询、PDO 强化功能和输入验证过滤。参数化查询将 SQL 查询和数据分开处理,防止恶意代码执行。 PDO 具有数据类型检查、错误处理和跨数据库兼容性。输入验证过滤在使用参数化查询前检查用户输入,去除恶意代码。结合这几种方法,构建多层防御体系,保…

    2025年12月11日
    000
  • 本地开发之战:ServBay 与 MAMP

    mamp 和 servbay:本地服务器解决方案深度对比 MAMP 和 ServBay 都是优秀的本地服务器搭建工具,但它们各有千秋。本文将深入比较两者的功能、优缺点,帮助您选择最合适的工具。 MAMP 与 ServBay 的核心差异 本地服务器对于简化开发流程至关重要,MAMP 作为一款成熟的工具…

    2025年12月11日 好文分享
    000
  • 如何选择合适的PHP 8开发工具?

    PHP 8開發工具選擇取決於項目規模和個人偏好。主流選項包括:程式碼編輯器/IDE:VS Code:免費、輕量級、可擴展,適合各種平台。PHPStorm:強大的功能集,但收費且資源需求高。Sublime Text:輕量級、自訂性高,可用於簡單的PHP開發。除錯工具:Xdebug:配合VS Code或…

    2025年12月11日
    000
  • 如何安装Nginx服务器并配置PHP 8?

    Nginx与PHP 8集成指南安装Nginx:使用apt软件包管理器(Ubuntu示例)。安装PHP 8:使用ppa源和apt软件包管理器(Ubuntu示例)。配置Nginx:添加location块处理PHP文件(根据系统路径修改socket)。测试配置文件并重启Nginx。定位问题:检查Nginx…

    2025年12月11日
    000
  • 如何配置PHP 8的扩展?

    如何配置 PHP 8 扩展?确认 PHP 配置文件 (php.ini) 位置。找到并更新 extension_dir 指令,指定扩展文件目录。通过在 php.ini 中添加 extension= 开头的行来启用扩展。保存 php.ini 并重启 Web 服务器或 PHP-FPM。 如何配置PHP 8…

    2025年12月11日
    000
  • 如何配置PHP 8的数据库连接?

    如何配置PHP 8数据库连接?掌握以下关键要点:选择PDO扩展: 推荐使用PDO,它更抽象、更灵活。设置DSN: 包含数据库信息,如主机、数据库名和字符集 (建议使用utf8mb4)。启用错误抛出: 使用PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION 来…

    2025年12月11日
    000
  • PHP7和PHP8的数据库支持差异

    PHP7和PHP8的数据库支持相比,PHP8在性能上大幅提升,执行速度提升~20%,预处理语句效率更高;还提供了异步操作等高级特性。但升级时要注意数据库驱动程序兼容性和代码修改,使用预处理语句防止SQL注入漏洞至关重要。 PHP7和PHP8的数据库支持:进化还是革命? 你可能在想,PHP7和PHP8…

    2025年12月11日
    000
  • PHP 书籍推荐

    php 和 mysql 学习资源推荐:从入门到高级 本文推荐一系列 PHP 和 MySQL 学习书籍,涵盖不同技能水平,从初学者到高级开发者都能找到合适的学习资料。 初学者 PHP 和 MySQL:忍者新手: 这本书专为初学者设计,重点讲解如何构建 Web 项目,并涵盖数据库实践、安全性和数据操作。…

    2025年12月11日 好文分享
    000
  • 如何部署PHP 8应用程序?

    部署 PHP 8 应用程序涉及以下步骤:选择 Linux 服务器并安装 PHP 8 和扩展。安装 Apache 或 Nginx 网络服务器。仔细配置 PHP 配置文件 (php.ini)。审查代码是否存在硬编码路径和环境变量依赖。使用版本控制(例如 Git)管理代码。实施自动化部署流程(例如 Ans…

    2025年12月11日
    000
  • 如何在 Ubuntu 上安装 PHP

    PHP 代表超文本预处理器,它是一种基于脚本的服务器端编程语言。PHP 有助于自动化各种服务器任务。它处理动态内容、数据库请求和数据预处理/显示等任务。 安装 PHP Ubuntu 像许多开发工具一样,PHP 有几个不同的版本 版本。在撰写本文时,PHP 7.4。和 8.1 是当前 支持和最常用的软…

    2025年12月11日 好文分享
    000
  • 了解 PHP 中的 PDO 以及为什么推荐使用它而不是 `mysql_*` 函数

    PHP 数据对象 (PDO):现代数据库交互的最佳实践 PHP 数据对象 (PDO) 是 PHP 的数据库访问抽象层,提供与多种数据库系统(MySQL、PostgreSQL、SQLite 等)交互的统一接口。 它已成为现代 PHP 开发中与数据库交互的首选方法,取代了已被弃用并移除的 mysql_*…

    2025年12月11日
    000
  • 常见的 PHP 安全问题以及如何预防

    PHP 安全漏洞及防御措施 网站安全是 Web 开发的核心。PHP 作为广泛使用的服务器端语言,若缺乏安全防护,极易遭受攻击。开发者必须了解常见漏洞并采取有效措施保护应用。本文将探讨常见的 PHP 安全问题及其解决方案。 1. SQL 注入 问题: 攻击者通过用户输入注入恶意 SQL 代码,操纵 S…

    2025年12月11日
    000
  • PHP7和PHP8的运行环境要求

    PHP7和PHP8的运行环境要求包括:兼容性问题、扩展库依赖关系、性能差异和安全隐患。升级前,必须进行代码测试以确保兼容性,梳理依赖关系以避免版本不匹配,以及建立测试环境以逐步升级。PHP8性能提升显著,但仍需注重代码优化。此外,还需更新安全策略以适应PHP8的安全改进。升级是一个需要耐心和细致的过…

    2025年12月11日
    000
  • 如何下载PHP 8?

    下载PHP 8的方法如下:直接使用预编译版本(推荐,适用于快速上手):从PHP官网下载适用于你的系统的版本。使用知名发行版(如XAMPP、WAMP)一键安装。下载源码自己编译(适用于高级用户):安装编译器(如GCC、Visual Studio)。下载PHP源码包并配置。编译并安装,注意潜在的错误。 …

    2025年12月11日
    000
  • 搭建PHP 8环境需要哪些准备工作?

    构建PHP 8环境需要以下步骤:选择操作系统,推荐Linux。安装PHP 8,同时考虑所需的扩展库。安装并配置数据库(如MySQL)。安装并配置Web服务器(如Nginx或Apache)。选择合适的开发工具(如PHPStorm或VS Code)。 搭建PHP 8环境? 这问题问得妙啊,看似简单,其实…

    2025年12月11日
    000
  • 在Windows上如何搭建PHP 8环境?

    搭建 PHP 8 环境分为以下步骤:安装 PHP 8,设置环境变量。修改 php.ini,指向扩展目录和设置时区。下载并启用所需扩展(如 MySQL)。测试环境配置,确保命令行运行 php -v 和运行 PHP 文件输出正常。仔细检查每个步骤并及时测试,避免后续麻烦。 在Windows上搭建PHP …

    2025年12月11日
    000

发表回复

登录后才能评论
关注微信