表数据量为300W+
1、先将sql整到navicat 中,排查了下条件,发现主要是order by 排序导致的问题。
2、看数据表索引,是否未添加,结果索引是有的。
3、看sql执行计划,发现了原因,key栏的索引并不是我们建立的想让它使用的索引。也就是说它执行时索引选错了。
解决办法:
1、在MySQL中提供了force index来强制优化器使用这个索引。
使用方法:select * from table_name force index (idx_a) where a = 100;
2、修改sql的查询参数,或条件参数,以达到让选择器正确选用的的情况。
例如:索引字段为 (a,b,c,d) 则 查询时只使用索引范围内的字段 select a,b,c,d from table