我们有一个用于归档旧数据的大型 MyISAM 表。这种归档每月执行一次,除了这些情况外,数据永远不会写入表中。无论如何要“告诉”MySQL 这个表是只读的,以便 MySQL 可以优化从这个表读取的性能?我查看了 MEMORY 存储引擎,但问题是该表太大以至于它会占用服务器内存的很大一部分,这是我不想要的。
希望我的问题足够清楚,我是数据库管理方面的新手,所以欢迎任何意见或建议。
最佳答案
而不是取消和重新压缩历史表:如果你想访问单个表的历史,你可以使用合并表来组合压缩的只读历史表。
因此假设您有一个事件表和具有相同表结构的压缩历史表,您可以使用以下方案:
表格:
compressed_month_1
compressed_month_2
active_month
创建合并表:
create table history_merge like active_month;
alter table history_merge
ENGINE=MRG_MyISAM
union (compressed_month_1,compressed_month_2);
一个月后,压缩active_month表并将其重命名为compressed_month_3。现在表格是:
compressed_month_1
compressed_month_2
compressed_month_3
active_month
你可以更新历史表
alter table history_merge
union (compressed_month_1, compressed_month_2, compressed_month_3);
关于mysql - 只读 MyISAM 表的加速,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2780537/