| Hint | Comment | 
  | and_equal | Choose an execution plan that uses an access path that merges the scans on several single-column indexes | 
  | antijoin |  | 
  | all_rows | Compare with first_rows | 
  | append,noappend | append: If a table or an index is specified withnologging, this hint applied with an insert statement produces a direct path insert which reduces generation of redo. | 
  | append_values | Similar to append, but applies toinsertstatements with avaluesclause (as opposed toinsertstatements that get their data from subqueries). | 
  | bind_aware | Force bind aware cursor sharing from the first execution | 
  | cache,nocache | When performing a full table scan, this hint places data blocks at the most recently used end of the LRU list of the buffer cache. Useful for (small) lookup tables. | 
  | cardinality | Not documented. For example select /*+ cardinality(t, 1234) */ from tq84_tab t;. This hint is superseded byopt_estimate. | 
  | change_dupkey_error_index | One of the three hints with semantic effect. Compare with ignore_row_on_dupkey_index | 
  | cluster | Perform a nested loop by the cluster index. Compare with the hashindex. | 
  | clustering,no_clustering |  | 
  | connect_by_filtering | Undocumented? Found in the shared SQL area. See also the CONNECT BY PUMPplan operation. | 
  | containers | Used together with the containers()clause in a container database (CDB root or application root). | 
  | cursor_sharing_exact | Set the value of cursor_sharingtoexactfor the duration of the SQL statement. | 
  | dbms_stats | Undocumented? Found in the shared SQL area. | 
  | driving_site | Specifies the «location» where a distributed query is executed. This hint is on Jonathan Lewis' list of the Big Five Hints | 
  | dynamic_sampling | Control some behavior of dynamic optimizer statistics (Generally: /*+ dynamic_sampling(0) */or for a given table/*+ dynamic_sampling(t 0) */) | 
  | dynamic_sampling_est_cdn | Undocumented? | 
  | enable_parallel_dml,disable_parallel_dml |  | 
  | expand_table,no_expand_table | See also the expand table query transformation | 
  | fact,no_fact | Used in the context of star tranformations to indicate that the hinted table should (not) be considered a fact table. | 
  | first_rows(n) | Optimize for returning the first nrows. Compare withall_rowsand SQL Server'sFAST nquery hint | 
  | fresh_mv | See Connor McDonald's youtube video Become a Materialized View Super Hero! | 
  | full | Access the data in a table with a full table scan, rather than using indexes (compare with the rowidand the variousindex*hints). | 
  | gather_plan_statistics | Collect extra metrics during SQL statement execution and make them available in v$sql_plan(?) andv$sql_plan_statistics | 
  | gather_optimizer_statistics,no_gather_optimizer_statistics | no_gather_optimizer_statisticssuppresses gathering statistics during bulk loads (such ascreate table as selectstatements). Such statistics can then later be gathered usinggather_optimizer_statisticsat statement level. | 
  | grouping |  | 
  | hash | Only applies to tables in a hash cluster. In order to join to tables with a hash join, use use_hash,hash_ajorhash_sj. Compare withuse_nlanduse_merge. | 
  | hash_aj |  | 
  | hash_sj |  | 
  | ignore_row_on_dupkey_index | One of the three hints with semantic effect. Compare with change_dupkey_error_index | 
  | ignore_where_clause | Undocumented hint, found in dynamic sampling queries. Not sure what it does, but does not seem to actually ignore a where clause, at least not if used in a top level query. | 
  | index,no_index | Use ( /*+ index(t) */) or don't use (/*+ noindex(t) */) an index on a table. Index name can additionally be specified:/*+ index(tab ix) */. The index to be used can be described in terms of the columns:/*+ index(tab tab(col_1, col_2…)) */ | 
  | index_asc |  | 
  | index_combine |  | 
  | index_desc |  | 
  | index_ffs,no_index_ffs |  | 
  | index_join |  | 
  | index_ss,no_index_ss |  | 
  | index_ss_asc |  | 
  | index_ss_desc |  | 
  | inline | Undocumented hint. Compare with materialize | 
  | inmemory,no_inmemory |  | 
  | inmemory_pruning,no_inmemory_pruning |  | 
  | leading | Specify the order of tables when joining them. Compare with ordered. | 
  | materialize | Undocumented hint. Store the result of a query in a withclause in a global temporary table. Useful if this result is referred to multiple times in the query. Compare withcacheandinline. Apparently, an inline view is materialized when it usesrownum. | 
  | merge,no_merge | Do or don't use complex view merging. These hints are on Jonathan Lewis' list of the Big Five Hints | 
  | merge_aj |  | 
  | merge_sj |  | 
  | model_min_analysis |  | 
  | monitor,no_monitor | Do (or don't) monitor SQL statement that take less (or more) than 5 seconds. See v$sql_monitorandv$sql_plan_monitor. (Is there also ano_monitoringhint?) | 
  | no_monitoring | Undocumented? Found in the shared SQL area. | 
  | native_full_outer_join,no_native_full_outer_join |  | 
  | nested_table_set_setid | Undocumented? Found in the shared SQL area. | 
  | nl_aj |  | 
  | nl_sj |  | 
  | nlj_batching,no_nlj_batching |  | 
  | nlj_prefetch,no_nlj_prefetch |  | 
  | no_expand |  | 
  | no_query_transformation | Prevents the optimizer from performing query transformation. | 
  | no_substrb_pad | Using query keywords ci_phrasematchorci_startswithresult in errors | 
  | no_sql_tune | ? | 
  | no_xml_query_rewrite |  | 
  | no_xmlindex_rewrite |  | 
  | no_zonemap |  | 
  | opaque_transform | Not documented. Seems to be related to a serial execution at a remote site. See also Doc ID 780503.1 and the column other_tagofplan_table | 
  | optimizer_features_enable |  | 
  | opt_estimate | opt_estimateinfluences costing and cardinality estimates. This hint supersedescardinality. | 
  | opt_param | Sets the value of a limited set of init parameters for the duration of the SQL statement. For example: /*+ opt_param('_optimizer_adaptive_plans', 'false') */or/*+ opt_param('_parallel_syspls_obey_force', 'false') */. | 
  | ordered | Join tables in the order in which they appear in the fromclause. Consider using theleadinghint instead ofordered. Compare with SQL Server's query hintforce order. | 
  | parallel,no_parallel |  | 
  | parallel_index,no_parallel_index |  | 
  | pq_concurrent_union,no_pq_concurrent_union | Enable/disable concurrent processing of unionandunion allstatements. | 
  | pq_distribute | Specifies the method with which rows are distributed among producer and consumer query servers. | 
  | pq_filter | Specifies how rows are processed when filtering correlated subqueries. | 
  | pq_skew,no_pq_skew |  | 
  | push_pred,no_push_pred | Where to apply join predicates in combination with non-merged view. These hints are on Jonathan Lewis' list of the Big Five Hints | 
  | push_subq,no_push_subq | push_subqinstructs the optimizer to evaluate unmerged subqueries as early as possible. These hints are on Jonathan Lewis' list of the Big Five Hints | 
  | px_join_filter,no_px_join_filter |  | 
  | qb_name |  | 
  | relational | Undocumented? Found in the shared SQL area. | 
  | result_cache,no_result_cache | /*+ result_cache */,/*+ result_cache(snapshot = 3600) */(3600 seconds or one hour),/*+ result_cache(shelflife = 3600) */,/*+ result_cache(syobj=true) */ | 
  | retry_on_row_change | One of the three hints with semantic effect. | 
  | rewrite,no_rewrite,norewrite | Rewrite a query so that uses one (or more?) materialized views, if possible. | 
  | rewrite_or_error | Throw ORA-30393: a query block in the statement did not rewrite to be thrown if a query fails to rewrite. | 
  | rowid | Access a row by its rowid. Compare with fulland the variousindex*hints. | 
  | rule | The only hint that cause the rule based optimizer (rather than the (cost based) optimizer to be used). | 
  | shared | shared(1)is the same asnoparallel.shared(n)forn> 1 is the same asparallel(n). | 
  | star | Try to use a star query plan. A star plan has the largest table in the query last in the join order and joins it with a nested loops join on a concatenated index. The STAR hint applies when there are at least three tables, the large table's concatenated index has at least three columns, and there are no conflicting access or join method hints. The optimizer also considers different permutations of the small tables. | 
  | star_transformation,no_star_transformation |  | 
  | statement_queuing,no_statement_queuing | Influences if a statement is queued with parallel statement queuing. See also the resmgr:pq queuedwait event. | 
  | swap_join_inputs,no_swap_join_inputs |  | 
  | unnest,no_unnest | Do or don't unnest subqueries. These hints are on Jonathan Lewis' list of the Big Five Hints | 
  | use_band,no_use_band |  | 
  | use_concat | See also the CONCATENATIONplan operation. | 
  | use_cube,no_use_cube |  | 
  | use_hash,no_use_hash | Compare with /*+ hash */ | 
  | use_merge,no_use_merge |  | 
  | use_nl,no_use_nl | use_nl(X)tells the optimizer to joinXusing a nested loop.use_nl(X Y)is a shorthand form for specifyinguse_nl(X) use_nl(Y). | 
  | use_nl_with_index |  | 
  | use_weak_name_resl | Undocumented? Found in the shared SQL area. | 
  | with_plsql | with_plsqlis not an optimizer hint. See ORA-32034: unsupported use of WITH clause | 
  | xmlindex_sel_idx_tbl | Undocumented? Found in the shared SQL area. |