控制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;
相关文章推荐
- 【MySQL笔记】mysql报错"ERROR 1206 (HY000): The total number of locks exceeds the lock table size"的解决方法
- 【MySQL笔记】Excel数据导入Mysql数据库的实现方法——Navicat
- 【MySQL笔记】MySql5安装图解教程
- Mysql之对一些数据类型的选用
- MySQL Timeout解析
- mysqli常用方法
- MySQL常用命令
- MySQL关闭过程详解和安全关闭MySQL的方法
- Mysql5-7-11 安装教程
- 将ubuntu14.04 从mysql从5.5删除之后安装5.7遇到的一些问题(本篇不讨论热升级)
- 修改MySQL 5.7.9 新版本的root密码方法
- Mysql导入导出时遇到的问题
- 基于MySQL实现按距离排序、范围查找geoHash
- Mysql中导入和导出数据库
- Mysql优化
- Mysql常用命令详解
- mysql半同步复制搭建及验证测试
- MySQL级联删除和更新
- MySQL 入门教程
- mysql 中文乱码解决方法