SET_INDEX_STATS プロシージャは、インデックス関連の情報を設定します。
構文
DBMS_STATS.SET_INDEX_STATS (
ownname VARCHAR2,
indname VARCHAR2,
partname VARCHAR2 DEFAULT NULL,
numrows NUMBER DEFAULT NULL,
force BOOLEAN DEFAULT FALSE,
avgrlen NUMBER DEFAULT NULL,
nummacroblks NUMBER DEFAULT NULL,
nummicroblks NUMBER DEFAULT NULL,
no_invalidate BOOLEAN DEFAULT FALSE,
tabname VARCHAR2 DEFAULT NULL);
パラメータ説明
パラメータ |
説明 |
|---|---|
| ownname | テーブルが存在するスキーマ。 |
| indname | インデックス名。 |
| partname | パーティション名。 |
| no_invalidate | 統計情報収集時にPlan Cacheをフラッシュするかどうか。TRUE に設定すると、統計情報収集時にPlan Cacheをフラッシュしません。 |
| numrows | インデックスの行数(パーティション)。 |
| force | インデックス統計情報を強制的に設定し、ロック状態を無視するかどうか。デフォルトは FALSE です。TRUE に設定すると、統計情報がロックされていてもインデックス統計情報を設定します。 |
| avgrlen | インデックステーブルの平均行長(バイト単位)。 |
| nummacroblks | インデックステーブルのマクロブロック数。 |
| nummicroblks | インデックステーブルのマイクロブロック数。 |
| tabname | テーブル名。 |
例外状況
エラーコード |
説明 |
|---|---|
| HY000 |
|
使用方法
このプロシージャを呼び出すには、テーブルの所有者である必要があります。
SYSが所有するオブジェクトについては、テーブルの所有者またはSYSDBA権限が必要です。オプティマイザーは、データキャッシュを通じてインデックスや統計テーブルへのアクセスにおけるキャッシュ済みブロック数を推定します。操作の総コストには、キャッシュされていないブロックをディスクから読み取るI/Oコスト、バッファからキャッシュ済みブロックを取得するCPUコスト、およびデータを処理するCPUコストが含まれます。
例
ユーザー testUser01 のインデックス idx1 に関する情報を設定します。
obclient> CALL DBMS_STATS.SET_INDEX_STATS('testUser01', 'idx1', numrows=>10, avgrlen=>10,
tabname=>'tbl1');
Query OK, 0 rows affected
説明
OceanBaseデータベースのOracleモードでは、インデックスは現在のユーザーに対して一意であるため、tabname を指定する必要はありません。しかし、MySQLモードではインデックスが現在のユーザーに対して一意ではないため、テーブル名を明示的に指定する必要があります。