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モードではインデックスが現在のユーザーに対して一意ではないため、テーブル名を明示的に指定する必要があります。