您的位置:首页 > 数据库 > MySQL

控制mysql的查询优化

2016-04-30 20:08 471 查看
控制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='[code]command
[,
command
]...';[/code]
可以单独设置一个,别的保持默认的设置
mysql> [code]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[/code]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
] ...[/code]
SELECT * FROM t1 USE INDEX (i1) IGNORE INDEX FOR ORDER BY (i2) ORDER BY a;

                                            
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: