説明
このステートメントは、バインドアウトラインとレートリミットルールを追加するために使用されます。SQL_TEXTで作成されたアウトラインの変更のみがサポートされています。
構文
ALTER OUTLINE outline_name ADD stmt [ TO target_stmt ];
パラメータの説明
| パラメータ | 説明 |
|---|---|
| outline_name | 変更対象のアウトライン名を指定します。 |
| stmt | 一般的には、Hintと元のパラメータを含むDMLステートメントです。 |
| TO target_stmt | TO target_stmt を指定しない場合、データベースが受け入れるSQLがパラメータ化された後、stmt からHintパラメータ化テキストを除いたものと同じであれば、そのSQLは stmt 内のHintに基づいて実行計画を生成してバインドされます。Hintを含むステートメントに対して固定計画を期待する場合は、元のSQLを指定するために TO target_stmt が必要です。 注意 target_stmt を使用する際は、stmt と target_stmt がHintを除いた後に完全に一致することが厳密に求められます。 |
例
ALTER OUTLINEを使用して、レートリミットルールを追加します。obclient> ALTER OUTLINE ol_1 ADD SELECT /*+max_concurrent(1)*/ * FROM t1 WHERE c1 = 1 and c2 = ?; obclient> ALTER OUTLINE ol_1 ADD SELECT /*+max_concurrent(1)*/ * FROM t1 WHERE c1 = ? and c2 = 1;ALTER OUTLINEを使用して、実行計画を追加します。obclient> CREATE OUTLINE ol_2 ON SELECT /*+max_concurrent(1)*/ * FROM t1,t2 WHERE t1.c1 = 1; obclient> ALTER OUTLINE ol_2 ADD SELECT /*+use_nl(t2)*/ * FROM t1,t2 WHERE t1.c1 = 1;
注意事項
同一の
outline_nameには、実行計画を1つしか指定できません。CREATE OUTLINEステートメントで実行計画が指定されている場合、ALTER OUTLINEを実行して追加することはできません。CREATE OUTLINEと同様に、ALTER OUTLINEの際には、レートリミットルールと実行計画を同時に指定することはできません。