MySQL8 常用Hint操作

文章目录

    • 一、Optimizer Hints
    • 二、Index Hints

一、Optimizer Hints

提示名称 描述 适用范围
BKA, NO_BKA 影响使用BKA联接处理 Query block,table
BNL, NO_BNL MySQL 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.18 Query 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顺序用于连接顺序的第一张table Query block
JOIN_SUFFIX 将提示中指定的table顺序用于联接顺序的最后一个table Query 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-joins Query 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) */ ...

二、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] ...

你可能感兴趣的:(MySQL)