1.229 OPTIMIZER_FEATURES_ENABLE
OPTIMIZER_FEATURES_ENABLE acts as an umbrella parameter for enabling a series of optimizer features based on an Oracle release number.
               
| Property | Description | 
|---|---|
| Parameter type | String | 
| Syntax | 
 | 
| Default value | 
 | 
| Modifiable | 
 | 
| Modifiable in a PDB | Yes | 
| Basic | No | 
For example, if you upgrade your database from release 11.1 to release 12.1, but you want to keep the release 11.1 optimizer behavior, you can do so by setting this parameter to 11.1.0.6. At a later time, you can try the enhancements introduced in releases up to and including release 12.1 by setting the parameter to 12.1.0.2.
                  
Table 1-6 describes some of the optimizer features that are enabled when you set the OPTIMIZER_FEATURES_ENABLE parameter to a 11.1 release.
                  
Table 1-7 describes some of the optimizer features that are enabled when you set the OPTIMIZER_FEATURES_ENABLE parameter to a 12.1 release.
                  
Table 1-8 describes some of the optimizer features that are enabled when you set the OPTIMIZER_FEATURES_ENABLE parameter to an Oracle Database 18c release.
                  
See Also:
Oracle Database SQL Tuning Guide for more information about the optimizer and for information about the features listed in the following tables
Table 1-6 Optimizer Features for Oracle Database 11g Releases
| Features | 11.1.0.6 | 11.1.0.7 | 11.2.0.1 | 11.2.0.2 | 11.2.0.3 | 11.2.0.4 | 
|---|---|---|---|---|---|---|
| Adaptive cursor sharing | X | X | X | X | X | X | 
| Join predicate pushdown | X | X | X | X | X | X | 
| Use extended statistics to estimate selectivity | X | X | X | X | X | X | 
| Use native implementation for full outer joins | X | X | X | X | X | X | 
| Partition pruning using join filtering | X | X | X | X | X | X | 
| Group by placement optimization | X | X | X | X | X | X | 
| Null aware antijoins | X | X | X | X | X | X | 
| Join predicate pushdown | X | X | X | X | X | X | 
| Join Factorization | 
 | 
 | X | X | X | X | 
| Cardinality Feedback | 
 | 
 | X | X | X | X | 
| Subquery Unnesting | 
 | 
 | X | X | X | X | 
| Subquery Coalescing | 
 | 
 | X | X | X | X | 
| Table Expansion | 
 | 
 | X | X | X | X | 
| Filtering Join Elimination | 
 | 
 | X | X | X | X | 
| Dynamic statistics enhancements | 
 | 
 | 
 | 
 | 
 | X | 
Table 1-7 Optimizer Features for Oracle Database 12c Releases
| Features | 12.1.0.1 | 12.1.0.2 | 12.2.0.1 | 
|---|---|---|---|
| Adaptive Query Optimization | X | X | X | 
| Online statistics gathering for bulk loads | X | X | X | 
| Session level statistics for Global Temporary Tables | X | X | X | 
| Multi-table left outer joins | X | X | X | 
| Lateral views | X | X | X | 
| Batch table access by rowid | X | X | X | 
| Null accepting semi joins | X | X | X | 
| Scalar subquery unnesting | X | X | X | 
| Conversion of joins that produce unnecessary duplicates to semi-joins | X | X | X | 
| Parallel Union and Parallel Union All operations | X | X | X | 
| Enhance Auto DOP | X | X | X | 
| Approximate count distinct | 
 | X | X | 
| Support for Oracle Database In-Memory | 
 | X | X | 
| Group-by and aggregation elimination | 
 | X | X | 
| Approximate percentile and median processing | 
 | 
 | X | 
| Query rewrite for approximate query processing | 
 | 
 | X | 
| Statistics advisor | 
 | 
 | X | 
| Support for sharded databases | 
 | 
 | X | 
| AWR source and auto capture filtering for SQL plan management | 
 | 
 | X | 
| Expression tracking | 
 | 
 | X | 
| Space-saving algorithm for partition synopses | 
 | 
 | X | 
| Oracle In-Memory Database statistics | 
 | 
 | X | 
| Support for sharding | 
 | 
 | X | 
| Cost-based OR expansion | 
 | 
 | X | 
| Sub-query elimination | 
 | 
 | X | 
| Multi-column key join elimination | 
 | 
 | X | 
Table 1-8 Optimizer Features for Oracle Database 18c Releases
| Features | 18.1.0 | 
|---|---|
| Adaptive Query Optimization | X | 
| Online statistics gathering for bulk loads | X | 
| Session level statistics for Global Temporary Tables | X | 
| Multi-table left outer joins | X | 
| Lateral views | X | 
| Batch table access by rowid | X | 
| Null accepting semi joins | X | 
| Scalar subquery unnesting | X | 
| Conversion of joins that produce unnecessary duplicates to semi-joins | X | 
| Parallel Union and Parallel Union All operations | X | 
| Enhance Auto DOP | X | 
| Approximate count distinct | X | 
| Support for Oracle Database In-Memory | X | 
| Group-by and aggregation elimination | X | 
| Approximate percentile and median processing | X | 
| Query rewrite for approximate query processing | X | 
| Statistics advisor | X | 
| Support for sharded databases | X | 
| AWR source and auto capture filtering for SQL plan management | X | 
| Expression tracking | X | 
| Space-saving algorithm for partition synopses | X | 
| Oracle In-Memory Database statistics | X | 
| Support for sharding | X | 
| Cost-based OR expansion | X | 
| Sub-query elimination | X | 
| Multi-column key join elimination | X |