IMPORT_TABLE_STATS プロシージャは、テーブルレベルの統計情報をインポートするために使用されます。
適用対象
この内容はOceanBaseデータベースEnterprise Editionにのみ適用されます。OceanBaseデータベースCommunity EditionはMySQLモードのみを提供します。
構文
DBMS_STATS.IMPORT_TABLE_STATS (
ownname VARCHAR2,
tabname VARCHAR2,
partname VARCHAR2 DEFAULT NULL,
stattab VARCHAR2,
cascade BOOLEAN DEFAULT TRUE,
statown VARCHAR2 DEFAULT NULL,
no_invalidate BOOLEAN DEFAULT FALSE,
force BOOLEAN DEFAULT FALSE
);
パラメータの説明
| パラメータ | 説明 |
|---|---|
| ownname | ユーザー名。ユーザー名を NULL に設定した場合、現在ログインしているユーザー名がデフォルトで使用されます。 |
| tabname | テーブル名。 |
| partname | テーブルパーティションの名前。テーブルがパーティション化されており、かつ partname が NULL の場合、グローバルおよびパーティションカラムの統計情報をインポートします |
| stattab | インポートするユーザー統計情報テーブルのテーブル名を指定します。 |
| cascade | TRUE の場合、このテーブルのカラムとインデックスの統計情報もエクスポートします。 |
| statown | インポートするユーザー統計情報テーブルのユーザー名を指定します。 |
| no_invalidate | 統計情報収集時にPlan Cacheをフラッシュするかどうか。TRUE に設定すると、統計情報収集時にPlan Cacheをフラッシュしません。 |
| force | 強制的にインポートし、ロック状態を無視するかどうか。デフォルトは FALSE です。TRUE に設定すると、統計情報がロックされていてもインポートされます。 |
異常時の動作
| エラーコード | 説明 |
|---|---|
| OBE-20000 | 対象のオブジェクトが存在しないか、権限が不足しています。 |
| OBE-20001 | ユーザー情報統計テーブル内の値が無効または矛盾しています。 |
使用方法
このプロシージャを呼び出すには、テーブルの所有者である必要があります。
SYSが所有するオブジェクトについては、テーブルの所有者またはSYSDBA権限を持っている必要があります。異なる文字セットを持つデータベース間で統計情報をエクスポートまたはインポートすることはサポートされていません。
例
ユーザー testUser02 のテーブル test_stat から、ユーザー testUser01 の tbl1 テーブルの統計情報をインポートします。
obclient> CALL DBMS_STATS.CREATE_STAT_TABLE('testUser02', 'test_stat');
Query OK, 0 rows affected
obclient> CALL DBMS_STATS.IMPORT_TABLE_STATS('testUser01', 'tbl1', stattab=>'test_stat', statown=>'testUser02');
Query OK, 0 rows affected