控制mysql评估执行计划数量的参数有下面的2个:
1optimizer_prune_level该变量 告诉优化器要跳过特定的计划,这个设置很少错过最优的执行计划,可以很明显的降低查询编译时间,默认的这个参数的值是1,如果你认为最优的计划被忽略了,那么可以设置这个值为0来关闭这个参数,会增加查询编译的时间。
2optimizer_search_depth,告诉优化器对每个不完整的机器优化器要评估多深,比如一个12,或13个表的查询,如果这个参数被关闭,那么可能编译的时间要几个小时设置几天,如果这个值设置成3或4,那么可能就需要几分钟了,可以设置成0来让优化器自动选择取值。
optimizer_switch系统变量可以控制优化器的行为,它的值是一个标记的集合,每个有on和off来控制优化器的行为是否启用,可以在全局或会话级别改变。为了看当前的优化器的设置,使用下面的方式
select @@optimizer_switch\G
为了改变optimizer_switch的值,使用
SET [GLOBAL|SESSION] optimizer_switch='command
[,command
]...';
可以单独设置一个,别的保持默认的设置
mysql>index hintSET optimizer_switch='index_merge_union=off,index_merge_sort_union=off';
mysql>SELECT @@optimizer_switch\G
*************************** 1. row *************************** @@optimizer_switch: index_merge=on,index_merge_union=off, index_merge_sort_union=off, index_merge_intersection=on, engine_condition_pushdown=on, index_condition_pushdown=on, mrr=on,mrr_cost_based=on, block_nested_loop=on,batched_key_access=off, materialization=on,semijoin=on,loosescan=on, firstmatch=on, subquery_materialization_cost_based=on, use_index_extensions=on
使用的语法
tbl_name
[[AS]alias
] [index_hint_list
]index_hint_list
:index_hint
[,index_hint
] ...index_hint
: USE {INDEX|KEY} [FOR {JOIN|ORDER BY|GROUP BY}] ([index_list
]) | IGNORE {INDEX|KEY} [FOR {JOIN|ORDER BY|GROUP BY}] (index_list
) | FORCE {INDEX|KEY} [FOR {JOIN|ORDER BY|GROUP BY}] (index_list
)index_list
:index_name
[,index_name
] ...
SELECT * FROM t1 USE INDEX (i1) IGNORE INDEX FOR ORDER BY (i2) ORDER BY a;