MySQL存储引擎MyISAM和InnoDB之间的比较

mysql中的数据用各种不同的技术存储在文件(或者内存)中。这些技术中的每一种技术都使用不同的存储机制、索引技巧、锁定水平并且最终提供广泛的不同的功能和能力。通过选择不同的技术,你能够获得额外的速度或者功能,从而改善你的应用的整体功能。

MySQL有多种存储引擎,MyISAM和InnoDB是其中常用的两种。这里介绍关于这两种引擎的一些基本概念(非深入介绍)。

MyISAM是MySQL的默认存储引擎,基于传统的ISAM类型,支持全文搜索,但不是事务安全的,而且不支持外键。每张MyISAM表存放在三个文件中:frm 文件存放表格定义;数据文件是MYD (MYData);索引文件是MYI (MYIndex)。

InnoDB是事务型引擎,支持回滚、崩溃恢复能力、多版本并发控制、ACID事务,支持行级锁定(InnoDB表的行锁不是绝对的,如果在执行一个SQL语句时MySQL不能确定要扫描的范围,InnoDB表同样会锁全表,如like操作时的SQL语句),以及提供与Oracle类型一致的不加锁读取方式。InnoDB存储它的表和索引在一个表空间中,表空间可以包含数个文件。

主要区别:

MyISAM是非事务安全型的,而InnoDB是事务安全型的。

MyISAM锁的粒度是表级,而InnoDB支持行级锁定。

MyISAM支持全文类型索引,而InnoDB不支持全文索引。

MyISAM相对简单,所以在效率上要优于InnoDB,小型应用可以考虑使用MyISAM。

MyISAM表是保存成文件的形式,在跨平台的数据转移中使用MyISAM存储会省去不少的麻烦。

InnoDB表比MyISAM表更安全,可以在保证数据不会丢失的情况下,切换非事务表到事务表(alter table tablename type=innodb)。

应用场景:

MyISAM管理非事务表。它提供高速存储和检索,以及全文搜索能力。如果应用中需要执行大量的SELECT查询,那么MyISAM是更好的选择。
InnoDB用于事务处理应用程序,具有众多特性,包括ACID事务支持。如果应用中需要执行大量的INSERT或UPDATE操作,则应该使用InnoDB,这样可以提高多用户并发操作的性能。
常用命令:

(1)查看表的存储类型(三种):

show create table tablename
show table status from  dbname  where name=tablename
mysqlshow  -u user -p password –status dbname tablename

(2)修改表的存储引擎:

alter table tablename type=InnoDB

(3)启动mysql数据库的命令行中添加以下参数使新发布的表都默认使用事务:

–default-table-type=InnoDB

(4)临时改变默认表类型:

set table_type=InnoDB
show variables like ‘table_type’

以上就是mysql的两种储存引擎MyISAM和InnoDB的简单介绍,以及两种引擎之间的区别介绍。

相关推荐:

关于mysql的MERGE储存引擎简单例子

mysql事务与mysql储存引擎_MySQL

MySQL两种引擎的有什么区别

以上就是MySQL存储引擎MyISAM和InnoDB之间的比较的详细内容,更多请关注【创想鸟】其它相关文章!

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

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/1796994.html

(0)
上一篇 2025年2月21日 11:54:39
下一篇 2025年2月21日 11:54:56

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • php如何实现mysql读写分离

    php实现mysql读写分离的方法:1、安装MySQL主从复制,将MySQL数据库实例设置为主从复制架构并启用二进制日志记录;2、创建PHP代码连接MySQL,创建两个不同的连接串,使用PHP的“PDO”扩展和“mysqlnd_ms”扩展来…

    2025年2月23日
    100
  • php如何查询mysql中的字段是否存在

    php查询mysql中的字段是否存在的方法是:1、利用SQL语句查询信息架构,执行一条“SHOW COLUMNS FROM”命令以获取指定表中所有列的信息,然后遍历结果集中的列名检查指定字段是否出现;2、使用SELECT查询语句验证,尝试访…

    2025年2月23日
    100
  • php怎么查询mysql数据数量

    php查询mysql数据数量的方法是:1、创建一个PHP示例文件,通过“mysqli_connect()”函数并建立一个到MySQL数据库的连接;2、连接建立后,执行SQL查询语句获取结果并将查询放入PHP代码中,并使用“mysqli_qu…

    2025年2月23日
    100
  • mysql支持php以外还有哪些

    mysql支持php以外还有:1、Java,广泛用于开发Web应用程序和数据库连接;2、Python,广泛应用于Web开发和数据库操作;3、C#,用于开发Windows应用程序和Web应用程序;4、Ruby,广泛应用于Web开发和脚本编程;…

    2025年2月23日
    100
  • php如何原生查询mysql

    php原生查询mysql的操作是:1、创建一个php示例文件;2、连接数据库;3、检查链接是否成功;4、执行查询语句;5、处理查询结果;6、关闭数据库连接即可。 本教程操作系统:Windows10系统、php8.1.3版本、Dell G3电…

    2025年2月23日
    100
  • 怎么修改php和mysql端口

    通过修改PHP和MySQL的配置文件修改php和mysql端口。详细介绍:1、修改PHP端口,打开PHP配置文件php.ini,在php.ini文件中查找“; Listen for TCP/IP connections on port; h…

    2025年2月23日
    100
  • mysql在php显示乱码怎么解决

    mysql在php显示乱码可以通过设置数据库字符集、设置PHP页面字符集、设置MySQL数据库和表的字符集以及进行编码转换等方法来解决。详细介绍:1、设置数据库字符集,通过设置字符集,可以确保从数据库中获取的数据以正确的编码显示在网页上;2…

    2025年2月23日
    100
  • php操作mysql数据库的扩展有哪些

    PHP 提供多种 MySQL 扩展:MySQLi:推荐用于 PHP 5.3 及以上版本,提供面向对象接口和高性能。PDO:可访问多种数据库的通用抽象层, 提供一致的接口。MySQLdb:已弃用,已被 MySQLi 取代。选择扩展时,应考虑 …

    2025年2月23日
    100
  • 使用PHP开发web应用程序有哪些优势

    PHP在Web应用程序开发中的优势:1. 开源免费;2. 易于学习;3. 丰富的库和框架;4. 跨平台兼容性;5. 与数据库无缝集成;6. 高效性能;7. 庞大的社区支持;8. 广泛的行业应用。 PHP开发Web应用程序的优势 PHP作为一…

    2025年2月23日
    100
  • php制作地图数据库应该储存哪些属性

    PHP 地图数据库属性包括:几何属性:表示要素形状(geom)。非几何属性(元数据):唯一标识符(id)、名称(name)、描述(description)、类型(type)、其他属性(properties)、标签(tags)、可见性(vis…

    2025年2月23日
    100

发表回复

登录后才能评论