説明
このステートメントは、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> CREATE TABLE tbl1 (col1 NUMBER, col2 NUMBER); obclient> CREATE OUTLINE outline1 ON SELECT /*+max_concurrent(1)*/ * FROM tbl1 WHERE col1 =1 AND col2 = 1; obclient> ALTER OUTLINE outline1 ADD SELECT /*+max_concurrent(1)*/ * FROM tbl1 WHERE col1 =1 AND col2 = ?; obclient> ALTER OUTLINE outline1 ADD SELECT /*+max_concurrent(1)*/ * FROM tbl1 WHERE col1 =? AND col2 = 1;同一の Signature で複数のレート制限ステートメントを作成できます。
obclient> CREATE TABLE tbl2 (col1 NUMBER, col2 NUMBER); obclient> CREATE OUTLINE olt_2 ON SELECT /*+max_concurrent(1)*/ c2,c1 FROM t1 WHERE c1 > 3 AND c2 = 1; obclient> ALTER OUTLINE olt_2 ADD SELECT /*+max_concurrent(2)*/ c2,c1 FROM t1 WHERE c1 > ? AND c2 = 1; obclient> ALTER OUTLINE olt_2 ADD SELECT /*+max_concurrent(2)*/ c2,c1 FROM t1 WHERE c1 > ? AND c2 = 2; obclient> ALTER OUTLINE olt_2 ADD SELECT /*+max_concurrent(0)*/ c2,c1 FROM t1 WHERE c1 > ? AND c2 = 3;
注意事項
同一の
outline_nameに対して実行計画は1つのみ指定できます。CREATE OUTLINEステートメントで実行計画を指定した場合、ALTER OUTLINEの実行時に追加することはできません。CREATE OUTLINEと同様に、ALTER OUTLINEの際にはレート制限ルールと実行計画を同時に指定することはできません。ALTER OUTLINEを実行する際には、outline_nameとsignatureが両方とも一致している必要があります。