MySQL的MEMORY存储引擎的替代品

我目前正在针对MyISAM表运行一些密集的SELECT查询.该表大约100 MiB(800,000行),它永远不会改变.

我需要提高我的脚本的性能,所以我正在考虑将表从MyISAM移动到MEMORY存储引擎,所以我可以将它完全加载到内存中.

除了MEMORY存储引擎,我有什么选择将100 MiB表加载到内存中?

最佳答案
无论你使用什么样的存储引擎,一个800k行的表都不应该对mysql有任何问题.大小为100 MB时,全表(数据和密钥)应该存在于内存中(MysqL密钥缓存,OS文件缓存,或者两者都适用).

首先检查指数.在大多数情况下,优化索引可以提高性能.除非你非常确定它们的形状,否则永远不要做任何其他事情.使用EXPLAIN调用查询,并监视使用无索引或错误索引的情况.这应该使用真实世界数据完成,而不是在带有测试数据的服务器上完成.

优化索引后,查询应该只需几分之一秒即可完成.如果查询仍然太慢,那么只需尝试通过在应用程序中使用缓存(memcached等)来避免运行它们.鉴于表中的数据永远不会改变,旧的缓存数据等应该没有任何问题.

相关文章

目录MySQL卸载环境查看是否已安装MySQL卸载mysql服务查看是否...
目录数据类型数据类型分类数值类型以TINYINT认识整型族有符号...
目录表的约束空属性非空约束(NOT NULL Constraint)默认值定...
目录函数时间日期函数:字符串函数数学函数其他函数 函数 时间...
目录使用C语言连接库的安装C APImysql_initmysql_real_conne...
目录用户用户管理查询所有用户查看当前用户查看当前连接数创...