控制mysql的查询优化

控制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> SET 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
index hint
使用的语法

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;






你可能感兴趣的:(MYSQL)