MySQL存储引擎–如何将MyISAM转换为InnoDB

大型网站发展缓慢的最大原因之一是他们的数据库没有得到优化。许多较老的站点仍在其数据库中使用MyISAM存储引擎。近年来,InnoDB表现出了更好的性能和更可靠的性能。使用InnoDB而不是MyISAM的一个重要原因是缺少完整的表级锁定。这使您的查询处理得更快。

  • InnoDB具有行级锁定。MyISAM只有完整的表级锁定。
  • InnoDB具有所谓的引用完整性,它涉及到支持外键(RDBMS)和关系约束,而MyISAM没有。
  • InnoDB支持事务,这意味着您可以提交和回滚。MyISAM没有。
  • InnoDB更可靠,因为它使用事务日志进行自动恢复。MyISAM没有。

你用的是MyISAM还是InnoDB?

如果你在一个全新的站点上运行,那么你很可能已经在使用innodbmysql存储引擎了。但是对于旧的站点,你可能需要做一个快速检查。有些站点甚至可能混合并匹配了MyISAM和InnoDB表,通过将它们全部转换,您可以看到改进。按照以下简单步骤进行检查。

第1步

登录到phpMyAdmin并点击进入mySQL数据库。

第2步

快速扫描或排序“Type”列,您可以看到您的表正在使用哪些存储引擎类型。在下面的示例中,您可以看到其中两个表仍在使用MyISAM。
在这里插入图片描述
或者,您可以运行一个查询来查看是否存在任何myISAM表。将“database”替换为数据库名称。

SELECT TABLE_NAME,
 ENGINE
FROM information_schema.TABLES
WHERE TABLE_SCHEMA = 'database' and ENGINE = 'myISAM'

使用phpMyAdmin将MyISAM转换为InnoDB

您可以很容易地将MyISAM转换为InnoDB。下面的示例使用wp\u comments表。只需运行ALTER命令将其转换为InnoDB存储引擎。注意:我们总是建议在对MySQL数据库执行任何操作之前备份它。

ALTER TABLE wp_comments ENGINE=InnoDB;

确保您运行的是MySQL
5.6.4或更高版本,否则,您可能会遇到InnoDB尚不支持全文索引的问题。如果你是Kinsta的客户,你不需要担心这个。

或者,也可以使用phpMyAdmin手动转换它们。只需单击myISAM表,单击“操作”选项卡,然后更改存储引擎。
在这里插入图片描述
译者附录:
使用InnoDB切记在服务器关机前关闭MySQL服务,否则会造成数据丢失。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当涉及到数据库操作时,事务和存储引擎是两个重要的概念。 1. 事务: 事务是一组数据库操作,被视为一个单独的工作单元,要么全部成功执行,要么全部失败回滚。事务的目的是确保数据库的一致性和完整性。 在MySQL中,使用以下语句来管理事务: - BEGIN 或 START TRANSACTION:开始一个事务。 - COMMIT:提交事务,将所有修改永久保存到数据库。 - ROLLBACK:回滚事务,放弃所有未提交的修改。 事务具有ACID属性: - 原子性(Atomicity):事务中的所有操作都要么全部执行成功,要么全部失败回滚。 - 一致性(Consistency):事务执行前后数据库从一个一致性状态转换到另一个一致性状态。 - 隔离性(Isolation):并发执行的事务之间是相互隔离的,每个事务感知不到其他事务的存在。 - 持久性(Durability):一旦事务提交,其结果将永久保存在数据库中,即使发生系统故障也不会丢失。 2. 存储引擎存储引擎数据库管理系统中负责数据存储和检索的组件。MySQL支持多种存储引擎,常见的有InnoDBMyISAM、Memory等。 不同的存储引擎具有不同的特点和适用场景: - InnoDB:默认的存储引擎,支持事务、行级锁、外键等特性,适用于大部分应用。 - MyISAM:不支持事务和行级锁,但具有较高的插入和查询速度,适用于读写频率较低的应用。 - Memory:将数据存储在内存中,读写速度非常快,但数据在数据库重启后会丢失,适用于缓存或临时数据。 通过在创建时指定不同的存储引擎,可以根据应用的需求选择合适的存储引擎来优化数据库性能和功能。例如,使用InnoDB存储引擎可以保证事务的一致性和隔离性,而使用MyISAM存储引擎可以获得更好的读写性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值