In the next two modules, we will explore the cost- and rule-based optimizer for Oracle SQL and learn about when they are appropriate for specific types of SQL statements.
Before we get into detail about the specifics of each mode, we will start by exploring the Oracle defaults for SQL optimizers and
understand why the defaults can have a tremendous impact on database performance.
By the time you finish this module, you should be able to:
Describe each optimizer mode
View and reset the default optimizer mode
Override the default optimizer mode for a query
Please note that in this module I will refer to SQL queries.
I say queries because SQL that changes rows (INSERT, UPDATE, DELETE) is not significantly impacted by the choice of SQL optimizer mode.
We will start our discussion with an overview of the optimizer modes.
RBO as a functionality is no longer supported. RBO still exists in Oracle 10g Release 1, but is an unsupported feature. No code changes have been made to
RBO and no bug fixes are provided. Oracle supports only the query optimizer,
and all applications running on Oracle Database 10g Release 1 (10.1) should use
||The optimizer uses a cost-based approach for all SQL statements in the session regardless of
the presence of statistics and optimizes with a goal of best throughput (minimum resource use
to complete the entire statement). This is the default value.
||The optimizer uses a cost-based approach, regardless of the presence of statistics, and
optimizes with a goal of best response time to return the first n number of rows; n can equal 1,
10, 100, or 1000.
||optimizer uses a mix of cost and heuristics to find a best plan for fast delivery of the first
Note: Using heuristics sometimes leads the query optimizer to generate a plan with a cost that
is significantly larger than the cost of a plan without applying the heuristic. FIRST_ROWS is
available for backward compatibility and plan stability; use FIRST_ROWS_n instead.
||This parameter value has been desupported.
||This parameter value has been desupported