KingbaseES enable_hint_table 可以看成类似 oracle outline 工具,可以在不修改SQL 的情况下,通过hint 改变SQL 的执行计划。
一、启用enable_hint_table
1、设置shared_preload_libraries 参数,增加 sys_hint_plan , 重启数据库
2、修改参数 sys_hint_plan.enable_hint=on , select sys_reload_conf()
3、create extension sys_hint_plan ;创建后,会新建 hint_plan.hints 表。
4、设置 set sys_hint_plan.enable_hint_table = on
二、举例说明
1、没使用 hint_plan.hints 时的执行计划
test=# delete from hint_plan.hints;
DELETE 1
test=# explain analyze select * from t1 where t1.id1 = 1;
QUERY PLAN
---------------------------------------------------------------------------------------------------------------
Bitmap Heap Scan on t1 (cost=4.20..13.67 rows=6 width=44) (actual time=0.002..0.002 rows=0 loops=1)
Recheck Cond: (id1 = 1