当前位置:   article > 正文

MySQL8 常用Hint操作_mysql8 hint

mysql8 hint

一、Optimizer Hints

提示名称描述适用范围
BKA, NO_BKA影响使用BKA联接处理Query block,table
BNL, NO_BNLMySQL 8.0.20之前的版本:影响块嵌套循环的连接处理;MySQL 8.0.18及更高版本:还影响哈希联接优化;MySQL 8.0.20及更高版本:仅影响哈希联接优化Query block,table
DERIVED_CONDITION_PUSHDOWN, NO_DERIVED_CONDITION_PUSHDOWN对物化派生table使用或忽略派生条件下推优化(在MySQL 8.0.22中添加)Query block,table
GROUP_INDEX, NO_GROUP_INDEX在GROUP BY操作中使用或忽略指定的一个或多个索引进行索引扫描 (在MySQL 8.0.20中添加)Index
HASH_JOIN, NO_HASH_JOIN影响哈希联接优化(仅适用于MySQL 8.0.18Query block,table
INDEX, NO_INDEX充当的组合JOIN_INDEX, GROUP_INDEX以及 ORDER_INDEX,或作为组合 NO_JOIN_INDEX, NO_GROUP_INDEX和 NO_ORDER_INDEX(由在MySQL 8.0.20)Index
INDEX_MERGE, NO_INDEX_MERGE影响索引合并优化table,Index
JOIN_FIXED_ORDER使用FROM子句中指定的table顺序作为连接顺序Query block
JOIN_INDEX, NO_JOIN_INDEX对任何访问方法使用或忽略指定的索引(在MySQL 8.0.20中添加)Index
JOIN_ORDER使用提示中指定的table顺序作为连接顺序Query block
JOIN_PREFIX将提示中指定的table顺序用于连接顺序的第一张tableQuery block
JOIN_SUFFIX将提示中指定的table顺序用于联接顺序的最后一个tableQuery block
MAX_EXECUTION_TIME限制语句执行时间Global
MERGE,NO_MERGE影响派生table/视图合并到外部Query block中table
MRR, NO_MRR影响多范围读取优化table,Index
NO_ICP影响索引条件下推式优化table,Global
NO_RANGE_OPTIMIZATION影响范围优化table,Index
ORDER_INDEX,NO_ORDER_INDEX使用或忽略指定的一个或多个索引对行进行排序(在MySQL 8.0.20中添加)Index
QB_NAME为Query block分配名称Query block
RESOURCE_GROUP在语句执行期间设置资源组Global
SEMIJOIN, NO_SEMIJOIN影响半联接策略;从MySQL 8.0.17开始,这也适用于anti-joinsQuery block
SKIP_SCAN, NO_SKIP_SCAN影响跳过扫描优化table,Index
SET_VAR在语句执行期间设置变量Global
SUBQUERY影响物化, IN至- EXISTS子查询配置的对策探讨Query block

hint用法

#基本语法
/*+ BKA(t1) */
/*+ BNL(t1, t2) */
/*+ NO_RANGE_OPTIMIZATION(t4 PRIMARY) */
/*+ QB_NAME(qb2) */
SELECT /*+ ... */ ...
INSERT /*+ ... */ ...
REPLACE /*+ ... */ ...
UPDATE /*+ ... */ ...
DELETE /*+ ... */ ...

#多个hint条件
SELECT /*+ BNL(t1) BKA(t2) */ ...
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

二、Index Hints

语法

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|FORCE} {INDEX|KEY}
      [FOR {JOIN|ORDER BY|GROUP BY}] (index_list)

index_list:
    index_name [, index_name] ...
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/688541
推荐阅读
相关标签
  

闽ICP备14008679号