我有一些删除查询要针对一些非常大的表(~100 GB)运行,我想尽可能地优化它们:
delete from table1 where column1 < date_sub(now(), interval 100 hour);
column1 是一datetime
列,我假设为该列创建索引将加快删除速度。除此之外,我能在这里做什么?使用该date_sub()
函数会减慢查询速度吗?我应该在运行查询之前计算该值吗?
delete from table2 where column2 = x;
column2 是 table2 的主键,所以根据 mysql 文档它已经是一个索引。我的问题是:索引类型是PRIMARY
,是一样的INDEX
吗?我是否必须制作另一个索引INDEX
以加快速度?
delete from table3 where column3 = y;
table3 有一个复合主键,即 column3 和 column4。所以我有一个主键索引,但由于删除查询不使用column4,我应该为column3创建一个单独的索引吗?或者组合的主键会做吗?
我想这些是非常基本的问题,但我找不到特定于我的情况的明确答案,所以任何帮助将不胜感激!