29 Migrating Stored Outlines to SQL Plan Baselines
Stored outline migration is the user-initiated process of converting stored outlines to SQL plan baselines. A SQL plan baseline is a set of plans proven to provide optimal performance.
Note:
Starting in Oracle Database 12c, stored outlines are deprecated. See "Migrating Stored Outlines to SQL Plan Baselines" for an alternative.
This chapter explains the concepts and tasks relating to stored outline migration. This chapter contains the following topics:
- About Stored Outline Migration
 A stored outline is a set of hints for a SQL statement.
- Preparing for Stored Outline Migration
 The goal is preparation is determining which stored outlines are eligible for migration.
- Migrating Outlines to Utilize SQL Plan Management Features
 You can migrate stored outline to SQL plan baselines.
- Migrating Outlines to Preserve Stored Outline Behavior
 You can migrate stored outlines to SQL plan baselines and preserve the original behavior of the stored outlines by creating fixed plan baselines.
- Performing Follow-Up Tasks After Stored Outline Migration
 After migrating outlines to SQL plan baselines, you must perform some follow-up work.
Parent topic: SQL Management Objects
29.1 About Stored Outline Migration
A stored outline is a set of hints for a SQL statement.
The hints direct the optimizer to choose a specific plan for the statement. A stored outline is a legacy technique for providing plan stability.
This section contains the following topics:
- Purpose of Stored Outline Migration
 If you rely on stored outlines to maintain plan stability and prevent performance regressions, then you can safely migrate from stored outlines to SQL plan baselines. After the migration, you can maintain the same plan stability while benefiting from the features provided by the SQL Plan Management framework.
- How Stored Outline Migration Works
 Stored outline migration is a user-initiated process that goes through multiple stages.
- User Interface for Stored Outline Migration
 You can use theDBMS_SPMpackage to perform the stored outline migration.
- Basic Steps in Stored Outline Migration
 The basic process is to prepare, migrate, and then clean up.
Parent topic: Migrating Stored Outlines to SQL Plan Baselines
29.1.1 Purpose of Stored Outline Migration
If you rely on stored outlines to maintain plan stability and prevent performance regressions, then you can safely migrate from stored outlines to SQL plan baselines. After the migration, you can maintain the same plan stability while benefiting from the features provided by the SQL Plan Management framework.
Stored outlines have the following disadvantages:
- 
                           Stored outlines cannot automatically evolve over time. Consequently, a stored outline may be optimal when you create it, but become a suboptimal plan after a database change, leading to performance degradation. 
- 
                           Hints in a stored outline can become invalid, as with an index hint on a dropped index. In such cases, the database still uses the outlines but excludes the invalid hints, producing a plan that is often worse than the original plan or the current best-cost plan generated by the optimizer. 
- 
                           For a SQL statement, the optimizer can only choose the plan defined in the stored outline in the currently specified category. The optimizer cannot choose from other stored outlines in different categories or the current cost-based plan even if they improve performance. 
- 
                           Stored outlines are a reactive tuning technique, which means that you only use a stored outline to address a performance problem after it has occurred. For example, you may implement a stored outline to correct the plan of a SQL statement that became high-load. In this case, you used stored outlines instead of proactively tuning the statement before it became high-load. 
The stored outline migration PL/SQL API helps solve the preceding problems in the following ways:
- 
                           SQL plan baselines enable the optimizer to use the same optimal plan and allow this plan to evolve over time. For a specified SQL statement, you can add new plans as SQL plan baselines after they are verified not to cause performance regressions. 
- 
                           SQL plan baselines prevent plans from becoming unreproducible because of invalid hints. If hints stored in a plan baseline become invalid, then the plan may not be reproducible by the optimizer. In this case, the optimizer selects an alternative reproducible plan baseline or the current best-cost plan generated by optimizer. 
- 
                           For a specific SQL statement, the database can maintain multiple plan baselines. The optimizer can choose from a set of optimal plans for a specific SQL statement instead of being restricted to a single plan per category, as required by stored outlines. 
Parent topic: About Stored Outline Migration
29.1.2 How Stored Outline Migration Works
Stored outline migration is a user-initiated process that goes through multiple stages.
This section explains how the database migrates stored outlines to SQL plan baselines. This information is important for performing the task of migrating stored outlines.
This section contains the following topics:
- Stages of Stored Outline Migration
 To migrate stored outlines, you specify the stores outlines. The database then creates and updates SQL plan baselines.
- Outline Categories and Baseline Modules
 An outline is a set of hints, whereas a SQL plan baseline is a set of plans.
Parent topic: About Stored Outline Migration
29.1.2.1 Stages of Stored Outline Migration
To migrate stored outlines, you specify the stores outlines. The database then creates and updates SQL plan baselines.
Figure 29-1 Stages of Stored Outline Migration

Description of "Figure 29-1 Stages of Stored Outline Migration"
The migration process has the following stages:
- 
                              The user invokes a function that specifies which outlines to migrate. 
- 
                              The database processes the outlines as follows: - 
                                    The database copies information in the outline needed by the plan baseline. The database copies it directly or calculates it based on information in the outline. For example, the text of the SQL statement exists in both schemas, so the database can copy the text from outline to baseline. 
- 
                                    The database reparses the hints to obtain information not in the outline. The plan hash value and plan cost cannot be derived from the existing information in the outline, which necessitates reparsing the hints. 
- 
                                    The database creates the baselines. 
 
- 
                                    
- 
                              The database obtains missing information when it chooses the SQL plan baseline for the first time to execute the SQL statement. The compilation environment and execution statistics are only available during execution when the plan baseline is parsed and compiled. 
The migration is complete only after the preceding phases complete.
Parent topic: How Stored Outline Migration Works
29.1.2.2 Outline Categories and Baseline Modules
An outline is a set of hints, whereas a SQL plan baseline is a set of plans.
Because they are different technologies, some functionality of outlines does not map exactly to functionality of baselines. For example, a single SQL statement can have multiple outlines, each of which is in a different outline category, but the only category that currently exists for baselines is DEFAULT. 
                        
The equivalent of a category for an outline is a module for a SQL plan baseline. Table 29-1 explains how outline categories map to modules.
Table 29-1 Outline Categories
| Concept | Description | Default Value | 
|---|---|---|
| Outline Category | Specifies a user-defined grouping for a set of stored outlines. You can use categories to maintain different stored outlines for a SQL statement. For example, a single statement can have an outline in the  Each SQL statement can have one or more stored outlines. Each stored outline is in one and only one outline category. A statement can have multiple stored outlines in different categories, but only one stored outline exists for each category of each statement. During migration, the database maps each outline category to a SQL plan baseline module. | 
 | 
| Baseline Module | Specifies a high-level function being performed. A SQL plan baseline can belong to one and only one module. | After an outline is migrated to a SQL plan baseline, the module name defaults to outline category name. | 
| Baseline Category | Only one SQL plan baseline category exists. This category is named  A statement can have multiple SQL plan baselines in the  | 
 | 
When migrating stored outlines to SQL plan baselines, Oracle Database maps every outline category to a SQL plan baseline module with the same name. As shown in the following diagram, the outline category OLTP is mapped to the baseline module OLTP. After migration, DEFAULT is a super-category that contains all SQL plan baselines.
                        
Parent topic: How Stored Outline Migration Works
29.1.3 User Interface for Stored Outline Migration
You can use the DBMS_SPM package to perform the stored outline migration. 
                     
Table 29-2 DBMS_SPM Functions Relating to Stored Outline Migration
| DBMS_SPM Function | Description | 
|---|---|
| 
 | Migrates existing stored outlines to plan baselines. Use either of the following formats: 
 | 
| 
 | Changes an attribute of a single plan or all plans associated with a SQL statement. | 
| 
 | Drops stored outlines that have been migrated to SQL plan baselines. The function finds stored outlines marked as  | 
You can control stored outline and plan baseline behavior with initialization and session parameters. Table 29-3 describes the relevant parameters. See Table 29-5 and Table 29-6 for an explanation of how these parameter settings interact.
Table 29-3 Parameters Relating to Stored Outline Migration
| Initialization or Session Parameter | Description | Parameter Type | 
|---|---|---|
| 
 | Determines whether Oracle Database automatically creates and stores an outline for each query submitted during the session. | Initialization parameter | 
| 
 | Enables or disables the automatic recognition of repeatable SQL statement and the generation of SQL plan baselines for these statements. | Initialization parameter | 
| 
 | Enables or disables the use of SQL plan baselines stored in SQL Management Base. | Initialization parameter | 
| 
 | Determines whether the optimizer uses stored outlines to generate execution plans. Note: This is a session parameter, not an initialization parameter. | Session | 
You can use database views to access information relating to stored outline migration. Table 29-4 describes the following main views.
Table 29-4 Views Relating to Stored Outline Migration
| View | Description | 
|---|---|
| 
 | Describes all stored outlines in the database. The  | 
| 
 | Displays information about the SQL plan baselines currently created for specific SQL statements. The  | 
See Also:
- 
                              Oracle Database PL/SQL Packages and Types Reference to learn about the DBMS_SPMpackage
- 
                              Oracle Database Reference to learn about the CREATE_STORED_OUTLINESinitialization parameter
Parent topic: About Stored Outline Migration
29.1.4 Basic Steps in Stored Outline Migration
The basic process is to prepare, migrate, and then clean up.
The basic steps are as follows:
- 
                           Prepare for stored outline migration. Review the migration prerequisites and determine how you want the migrated plan baselines to behave. 
- 
                           Perform either of the following tasks: - 
                                 Migrate to baselines to use SQL Plan Management features. See "Migrating Outlines to Utilize SQL Plan Management Features". 
- 
                                 Migrate to baselines while exactly preserving the behavior of the stored outlines. See "Migrating Outlines to Preserve Stored Outline Behavior". 
 
- 
                                 
- 
                           Perform post-migration confirmation and cleanup. See "Performing Follow-Up Tasks After Stored Outline Migration". 
Parent topic: About Stored Outline Migration
29.2 Preparing for Stored Outline Migration
The goal is preparation is determining which stored outlines are eligible for migration.
To prepare for stored outline migration:
- 
                           Connect SQL*Plus to the database with SYSDBAprivileges or theEXECUTEprivilege on theDBMS_SPMpackage.
- 
                           Query the stored outlines in the database. The following example queries all stored outlines that have not been migrated to SQL plan baselines: SELECT NAME, CATEGORY, SQL_TEXT FROM DBA_OUTLINES WHERE MIGRATED = 'NOT-MIGRATED';
- 
                           Determine which stored outlines meet the following prerequisites for migration eligibility: - 
                                 The statement must not be a run-time INSERT AS SELECTstatement.
- 
                                 The statement must not reference a remote object. 
- 
                                 This statement must not be a private stored outline. 
 
- 
                                 
- 
                           Decide whether to migrate all outlines, specified stored outlines, or outlines belonging to a specified outline category. If you do not decide to migrate all outlines, then identify the outlines or categories that you intend to migrate. 
- 
                           Decide whether the stored outlines migrated to SQL plan baselines use fixed plans or nonfixed plans: - 
                                 Fixed plans A fixed plan is frozen. If a fixed plan is reproducible using the hints stored in plan baseline, then the optimizer always chooses the lowest-cost fixed plan baseline over plan baselines that are not fixed. Essentially, a fixed plan baseline acts as a stored outline with valid hints. A fixed plan is reproducible when the database can parse the statement based on the hints stored in the plan baseline and create a plan with the same plan hash value as the one in the plan baseline. If one of more of the hints become invalid, then the database may not be able to create a plan with the same plan hash value. In this case, the plan is nonreproducible. If a fixed plan cannot be reproduced when parsed using its hints, then the optimizer chooses a different plan, which can be either of the following: - 
                                       Another plan for the SQL plan baseline 
- 
                                       The current cost-based plan created by the optimizer 
 In some cases, a performance regression occurs because of the different plan, requiring SQL tuning. 
- 
                                       
- 
                                 Nonfixed plans If a plan baseline does not contain fixed plans, then SQL Plan Management considers the plans equally when picking a plan for a SQL statement. 
 
- 
                                 
- 
                           Before beginning the actual migration, ensure that the Oracle database meets the following prerequisites: - 
                                 The database must be Enterprise Edition. 
- 
                                 The database must be open and not in a suspended state. 
- 
                                 The database must not be in restricted access (DBA), read-only, or migrate mode. 
- 
                                 Oracle Call Interface (OCI) must be available. 
 
- 
                                 
See Also:
- 
                           Oracle Database Administrator’s Guide to learn about administrator privileges 
- 
                           Oracle Database Reference to learn about the DBA_OUTLINESviews
Parent topic: Migrating Stored Outlines to SQL Plan Baselines
29.3 Migrating Outlines to Utilize SQL Plan Management Features
You can migrate stored outline to SQL plan baselines.
The goals of this task are as follows:
- 
                           To allow SQL Plan Management to select from all plans in a plan baseline for a SQL statement instead of applying the same fixed plan after migration 
- 
                           To allow the SQL plan baseline to evolve in the face of database changes by adding new plans to the baseline 
Assumptions
This tutorial assumes the following:
- 
                           You migrate all outlines. To migrate specific outlines, use the DBMS_SPM.MIGRATE_STORED_OUTLINEfunction.
- 
                           You want the module names of the baselines to be identical to the category names of the migrated outlines. 
- 
                           You do not want the SQL plans to be fixed. By default, generated plans are not fixed and SQL Plan Management considers all plans equally when picking a plan for a SQL statement. This situation permits the advanced feature of plan evolution to capture new plans for a SQL statement, verify their performance, and accept these new plans into the plan baseline. 
To migrate stored outlines to SQL plan baselines:
- 
                           Connect SQL*Plus to the database with the appropriate privileges. 
- 
                           Call PL/SQL function MIGRATE_STORED_OUTLINE.The following sample PL/SQL block migrates all stored outlines to fixed baselines: DECLARE my_report CLOB; BEGIN my_outlines := DBMS_SPM.MIGRATE_STORED_OUTLINE( attribute_name => 'all' ); END; /
See Also:
- 
                           Oracle Database PL/SQL Packages and Types Reference to learn about the DBMS_SPMpackage
- 
                           Oracle Database SQL Language Reference to learn about the ALTER SYSTEMstatement
Parent topic: Migrating Stored Outlines to SQL Plan Baselines
29.4 Migrating Outlines to Preserve Stored Outline Behavior
You can migrate stored outlines to SQL plan baselines and preserve the original behavior of the stored outlines by creating fixed plan baselines.
A fixed plan has higher priority over other plans for the same SQL statement. If a plan is fixed, then the plan baseline cannot be evolved. The database does not add new plans to a plan baseline that contains a fixed plan.
Assumptions
This tutorial assumes the following:
- 
                           You want to migrate only the stored outlines in the category named firstrow.
- 
                           You want the module names of the baselines to be identical to the category names of the migrated outlines. 
To migrate stored outlines to plan baselines:
- 
                           Connect SQL*Plus to the database with the appropriate privileges. 
- 
                           Call PL/SQL function MIGRATE_STORED_OUTLINE.The following sample PL/SQL block migrates stored outlines in the category firstrowto fixed baselines:DECLARE my_report CLOB; BEGIN my_outlines := DBMS_SPM.MIGRATE_STORED_OUTLINE( attribute_name => 'category', attribute_value => 'firstrow', fixed => 'YES' ); END; /After migration, the SQL plan baselines is in module firstrowand categoryDEFAULT.
See Also:
- 
                           Oracle Database PL/SQL Packages and Types Reference for syntax and semantics of the DBMS_SPM.MIGRATE_STORED_OUTLINEfunction
- 
                           Oracle Database SQL Language Reference to learn about the ALTER SYSTEMstatement
Parent topic: Migrating Stored Outlines to SQL Plan Baselines
29.5 Performing Follow-Up Tasks After Stored Outline Migration
After migrating outlines to SQL plan baselines, you must perform some follow-up work.
The goals of this task are as follows:
- 
                           To configure the database to use plan baselines instead of stored outlines for stored outlines that have been migrated to SQL plan baselines 
- 
                           To create SQL plan baselines instead of stored outlines for future SQL statements 
- 
                           To drop the stored outlines that have been migrated to SQL plan baselines 
This section explains how to set initialization parameters relating to stored outlines and plan baselines. The OPTIMIZER_CAPTURE_SQL_PLAN_BASELINES and CREATE_STORED_OUTLINES initialization parameters determine how and when the database creates stored outlines and SQL plan baselines. Table 29-5 explains the interaction between these parameters.
                     
Table 29-5 Creation of Outlines and Baselines
| CREATE_STORED_OUTLINES Initialization Parameter | OPTIMIZER_CAPTURE_SQL_PLAN_BASELINES Initialization Parameter | Database Behavior | 
|---|---|---|
| 
 | 
 | When executing a SQL statement, the database does not create stored outlines or SQL plan baselines. | 
| 
 | 
 | The automatic recognition of repeatable SQL statements and the generation of SQL plan baselines for these statements is enabled. When executing a SQL statement, the database creates only new SQL plan baselines (if they do not exist) with the category name  | 
| 
 | 
 | Oracle Database automatically creates and stores an outline for each query submitted during the session. When executing a SQL statement, the database creates only new stored outlines (if they do not exist) with the category name  | 
| 
 | 
 | When executing a SQL statement, the database creates only new stored outlines (if they do not exist) with the specified category name for the statement. | 
| 
 | 
 | Oracle Database automatically creates and stores an outline for each query submitted during the session. The automatic recognition of repeatable SQL statements and the generation of SQL plan baselines for these statements is also enabled. When executing a SQL statement, the database creates both stored outlines and SQL plan baselines with the category name  | 
| 
 | 
 | Oracle Database automatically creates and stores an outline for each query submitted during the session. The automatic recognition of repeatable SQL statements and the generation of SQL plan baselines for these statements is also enabled. When executing a SQL statement, the database creates stored outlines with the specified category name and SQL plan baselines with the category name  | 
The USE_STORED_OUTLINES session parameter (it is not an initialization parameter) and OPTIMIZER_USE_SQL_PLAN_BASELINES initialization parameter determine how the database uses stored outlines and plan baselines. Table 29-6 explains how these parameters interact.
                     
Table 29-6 Use of Stored Outlines and SQL Plan Baselines
| USE_STORED_OUTLINES Session Parameter | OPTIMIZER_USE_SQL_PLAN_BASELINES Initialization Parameter | Database Behavior | 
|---|---|---|
| 
 | 
 | When choosing a plan for a SQL statement, the database does not use stored outlines or plan baselines. | 
| 
 | 
 | When choosing a plan for a SQL statement, the database uses only SQL plan baselines. | 
| 
 | 
 | When choosing a plan for a SQL statement, the database uses stored outlines with the category name  | 
| 
 | 
 | When choosing a plan for a SQL statement, the database uses stored outlines with the specified category name. If a stored outline with the specified category name does not exist, then the database uses a stored outline in the  | 
| 
 | 
 | When choosing a plan for a SQL statement, stored outlines take priority over plan baselines. If a stored outline with the category name  | 
| 
 | 
 | When choosing a plan for a SQL statement, stored outlines take priority over plan baselines. If a stored outline with the specified category name or the  | 
Assumptions
This tutorial assumes the following:
- 
                           You have completed the basic steps in the stored outline migration. 
- 
                           Some stored outlines may have been created before Oracle Database 10g. Hints in releases before Oracle Database 10g use a local hint format. After migration, hints stored in a plan baseline use the global hints format introduced in Oracle Database 10g. 
To place the database in the proper state after the migration:
- 
                           Connect SQL*Plus to the database with the appropriate privileges, and then check that SQL plan baselines have been created as the result of migration. Ensure that the plans are enabled and accepted. For example, enter the following query (partial sample output included): SELECT SQL_HANDLE, PLAN_NAME, ORIGIN, ENABLED, ACCEPTED, FIXED, MODULE FROM DBA_SQL_PLAN_BASELINES; SQL_HANDLE PLAN_NAME ORIGIN ENA ACC FIX MODULE ------------------------- ---------- -------------- --- --- --- ------ SYS_SQL_f44779f7089c8fab STMT01 STORED-OUTLINE YES YES NO DEFAULT . . .
- 
                           Optionally, change the attributes of the SQL plan baselines. For example, the following statement changes the status of the baseline for the specified SQL statement to fixed:DECLARE v_cnt PLS_INTEGER; BEGIN v_cnt := DBMS_SPM.ALTER_SQL_PLAN_BASELINE( sql_handle=>'SYS_SQL_f44779f7089c8fab', attribute_name=>'FIXED', attribute_value=>'NO'); DBMS_OUTPUT.PUT_LINE('Plans altered: ' || v_cnt); END; /
- 
                           Check the status of the original stored outlines. For example, enter the following query (partial sample output included): SELECT NAME, OWNER, CATEGORY, USED, MIGRATED FROM DBA_OUTLINES ORDER BY NAME; NAME OWNER CATEGORY USED MIGRATED ---------- ---------- ---------- ------ ------------ STMT01 SYS DEFAULT USED MIGRATED STMT02 SYS DEFAULT USED MIGRATED . . .
- 
                           Drop all stored outlines that have been migrated to SQL plan baselines. For example, the following statements drops all stored outlines with status MIGRATEDinDBA_OUTLINES:DECLARE v_cnt PLS_INTEGER; BEGIN v_cnt := DBMS_SPM.DROP_MIGRATED_STORED_OUTLINE(); DBMS_OUTPUT.PUT_LINE('Migrated stored outlines dropped: ' || v_cnt); END; /
- 
                           Set initialization parameters so that: - 
                                 When executing a SQL statement, the database creates plan baselines but does not create stored outlines. 
- 
                                 The database only uses stored outlines when the equivalent SQL plan baselines do not exist. 
 For example, the following SQL statements instruct the database to create SQL plan baselines instead of stored outlines when a SQL statement is executed. The example also instructs the database to apply a stored outline in category allrowsorDEFAULTonly if it exists and has not been migrated to a SQL plan baseline. In other cases, the database applies SQL plan baselines instead.ALTER SYSTEM SET CREATE_STORED_OUTLINE = false SCOPE = BOTH; ALTER SYSTEM SET OPTIMIZER_CAPTURE_SQL_PLAN_BASELINES = true SCOPE = BOTH; ALTER SYSTEM SET OPTIMIZER_USE_SQL_PLAN_BASELINES = true SCOPE = BOTH; ALTER SESSION SET USE_STORED_OUTLINES = allrows SCOPE = BOTH;
- 
                                 
See Also:
- 
                           Oracle Database PL/SQL Packages and Types Reference to learn about the DBMS_SPMpackage
- 
                           Oracle Database Reference to learn about the CREATE_STORED_OUTLINESinitialization parameter
Parent topic: Migrating Stored Outlines to SQL Plan Baselines
