功能 | 命令行 | 说明 |
开启并行查询 | SELECT /*+PARALLEL(x)*/ ... FROM ...; | x 需大于0,x 表示该条 SQL 语句所使用的并行查询并行度。 |
关闭并行查询 | SELECT /*+PARALLEL(x)*/ ... FROM ...; | x 设置为0,表示关闭并行查询能力。 |
指定并行表 | 可通过以下两种方式指定允许哪些表执行或不执行并行查询计划: 通过 PARALLEL 可指定表执行并行查询计划 SELECT /*+PARALLEL(t)*/ ... FROM ...; 通过 NO_PARALLEL 可以指定表禁止执行并行查询计划 SELECT /*+NO_PARALLEL(t)*/ ... FROM ...; | t 为表的名称。 |
同时指定并行表与并行查询并行度 | SELECT /*+PARALLEL(t x)*/ * ... FROM ...; | x 需大于0,x 表示该条 SQL 语句所使用的并行查询并行度,t 为表的名称。 |
通过 hint 语句设置 session 级参数,仅对指定 SQL 语句生效 | SELECT /*+SET_VAR(var=n)*/ * ... FROM ...; | var 为支持 session 作用域的并行查询参数。 |
select /*+PARALLEL()*/ * FROM t1,t2;
强制并行度为 txsql_parallel_degree 所设置的数值(默认并行度)执行并行查询,当语句不符合并行查询执行条件时,将回退为串行查询。select /*+PARALLEL(4)*/ * FROM t1,t2;
无论系统默认并行度数值为多少,强制该条语句使用并行度为4执行并行查询,设置该条语句的 txsql_parallel_degree = 4 ,当语句不符合并行查询执行条件时,将回退为串行查询。select /*+PARALLEL(t1)*/ * FROM t1,t2;
选择 t1 表执行并行查询,并行度为系统默认并行度,当 t1 表小于 txsql_parallel_table_record_threshold 所设置的值时,将回退为串行查询。select /*+PARALLEL(t1 8)*/ * FROM t1,t2;
选择 t1 表执行并行查询,并行度为8,当 t1 表小于 txsql_parallel_table_record_threshold 所设置的值时,将回退为串行查询。select /*+NO_PARALLEL(t1)*/ * FROM t1,t2;
选择 t1 表禁止执行并行查询,当 t1 表大于 txsql_parallel_table_record_threshold 所设置的值时,将回退为串行查询。select /*+SET_VAR(txsql_parallel_degree=8)*/ * FROM t1,t2;
无论系统默认并行度数值为多少,强制该条语句使用并行度为8执行并行查询,设置该条语句的 txsql_parallel_degree = 8。select /*+SET_VAR(txsql_parallel_cost_threshold=1000)*/ * FROM t1,t2
设置该条语句的 txsql_parallel_cost_threshold=1000,当该条语句的执行代价大于1000时,即可使用并行查询。select /*+SET_VAR(txsql_optimizer_context_max_mem_size=500000)*/ * FROM t1,t2
设置单条语句的 txsql_optimizer_context_max_mem_size=500000,该条语句可申请的并行查询计划环境最大内存限制调整为500000。
本页内容是否解决了您的问题?