DBMS_CACHEパッケージ
DBMS_CACHEパッケージは、Autonomous AI Databaseインスタンスのレイク・キャッシュの自動キャッシュを容易にします。これには、外部表およびマウントされたカタログを介して公開される表に対して作成されたキャッシュが含まれます。
DBMS_CACHEサブプログラムの要約
この表は、DBMS_CACHEパッケージに含まれるサブプログラムの概要を示しています。
| サブプログラム | 摘要 |
|---|---|
| CLEARプロシージャ | 指定されたユーザーのすべてのレイク・キャッシュをクリアします。 |
| GET_GLOBAL_PROPERTYプロシージャ | 自動レイク・キャッシュ・プロパティを取得します。 |
| GET_USER_PROPERTYプロシージャ | 指定されたユーザーの自動レイク・キャッシュ・プロパティを取得します。 |
| REFRESHプロシージャ | 指定したユーザーのすべてのレイク・キャッシュをリフレッシュします。 |
| SET_GLOBAL_PROPERTYプロシージャ | すべてのデータベース・ユーザーの自動レイク・キャッシュ・プリファレンスを指定します。 |
| SET_USER_PROPERTYプロシージャ | 指定したユーザーの自動レイク・キャッシュ・プリファレンスを指定します。 |
CLEARプロシージャ
DBMS_CACHE.CLEARプロシージャを使用して、指定したユーザーのすべてのレイク・キャッシュを削除します。
DBMS_CACHE.CLEARプロシージャは、データベース表に対するDROPコマンドの動作と同様に、すべてのレイク・キャッシュを削除し、ストレージ領域を解放します。
構文
DBMS_CACHE.CLEAR (
owner IN VARCHAR2
);パラメータ
| パラメータ | 摘要 |
|---|---|
owner |
スキーマ名を指定します。 |
例
BEGIN
DBMS_CACHE.CLEAR (
owner => 'SALES');
END;
/使用上のノート
- キャッシュをクリアするには、
ADMINユーザーとしてログインするか、DBMS_CACHEパッケージに対するEXECUTE権限を持っている必要があります。
GET_GLOBAL_PROPERTYプロシージャ
DBMS_CACHE.GET_GLOBAL_PROPERTYプロシージャは、データベース内のすべてのユーザーの自動レイク・キャッシュ・プリファレンスを取得します。このプロシージャはオーバーロードされています。
構文
DBMS_CACHE.GET_GLOBAL_PROPERTY (
property_name IN VARCHAR2,
property_value_num OUT VARCHAR2);
DBMS_CACHE.GET_GLOBAL_PROPERTY (
property_name IN VARCHAR2,
property_value_str OUT VARCHAR2);パラメータ
| パラメータ | 摘要 |
|---|---|
property_name |
プロパティ名を指定します。
|
property_value_num |
指定されたプロパティ名のNUMBER値を取得します。 |
property_value_str |
指定したプロパティ名のSTRING値を取り出します。 |
例
SET SERVEROUTPUT ON;
DECLARE
cache_property NUMBER;
BEGIN
DBMS_CACHE.GET_GLOBAL_PROPERTY (
property_name => 'MAX_CACHE_SIZE',
property_value => cache_property
);
DBMS_OUTPUT.PUT_LINE('MAX_CACHE_SIZE = ' || cache_property);
END;
/使用上のノート
- このプロシージャを実行するには、
ADMINユーザーとしてログインするか、DBMS_CACHEパッケージに対するEXECUTE権限を持っている必要があります。
SET_GLOBAL_PROPERTYプロシージャ
DBMS_CACHE.SET_GLOBAL_PROPERTYプロシージャを使用して、データベースの自動キャッシュを有効にするプロパティを含め、すべてのデータベース・ユーザーのAUTOキャッシュ・プロパティを設定します。このプロシージャはオーバーロードされています。
デフォルトでは、外部表の自動キャッシュは無効になっています。これを有効にするには、DBMS_CACHE.SET_GLOBAL_PROPERTYプロシージャのMAX_CACHE_SIZEまたはMAX_CACHE_SIZEプロパティを使用して、キャッシュ・サイズを0以外の値に設定します。これにより、データベースの自動キャッシュがグローバルに有効になります。
構文
DBMS_CACHE.SET_GLOBAL_PROPERTY (
property_name IN VARCHAR2,
property_value_num IN NUMBER);
DBMS_CACHE.SET_GLOBAL_PROPERTY (
property_name IN VARCHAR2,
property_value_str IN VARCHAR2);パラメータ
| パラメータ | 摘要 |
|---|---|
property_name |
プロパティ名を指定します。
|
property_value_num |
指定されたプロパティ名のNUMBER値を指定します。 |
property_value_str |
指定されたプロパティ名のSTRING値を指定します。 |
例
BEGIN
DBMS_CACHE.SET_GLOBAL_PROPERTY (
property_name => 'MAX_CACHE_SIZE',
property_value_num => 50);
END;
/BEGIN
DBMS_CACHE.SET_GLOBAL_PROPERTY (
property_name => 'AUTO_REFRESH_MODE',
property_value_str => 'NEW');
END;
/BEGIN
DBMS_CACHE.SET_GLOBAL_PROPERTY (
property_name => 'MAX_REFRESH_WINDOW',
property_value_num => 20);
END;
/使用上のノート
-
このプロシージャを実行するには、
ADMINユーザーとしてログインするか、DBMS_CACHEパッケージに対するEXECUTE権限を持っている必要があります。 -
MAX_REFRESH_WINDOWプロパティは、レイク・キャッシュのリフレッシュに許可される最大時間を秒単位で指定します。リフレッシュが指定された制限を超えると、キャッシュ・リフレッシュは正常に終了し、残りの適格キャッシュは次のリフレッシュ・サイクルのためにキューに入れられます。 -
DBMS_CACHE.REFRESHプロシージャを使用してキャッシュをリフレッシュする場合、プロシージャ・パラメータはAUTO_REFRESH_MODEプロパティよりも優先されます。詳細は、REFRESHプロシージャを参照してください。
REFRESHプロシージャ
DBMS_CACHE.REFRESHプロシージャを使用して、指定したユーザーのすべてのAUTOレイク・キャッシュをリフレッシュします。
構文
DBMS_CACHE.REFRESH (
owner IN VARCHAR2,
refresh_type IN VARCHAR2 DEFAULT ALL
);パラメータ
| パラメータ | 摘要 |
|---|---|
owner |
スキーマ名を指定します。 |
refresh_type |
リフレッシュ・オプションを指定します。 有効な
このパラメータはオプションで、デフォルト値は |
例
BEGIN
DBMS_CACHE.REFRESH (
owner => 'SALES',
refresh_type => 'CURRENT');
END;
/使用上のノート
-
このプロシージャを実行するには、
ADMINユーザーとしてログインするか、DBMS_CACHEパッケージに対するEXECUTE権限を持っている必要があります。 -
refresh_typeパラメータの値を指定しない場合、Oracleはauto_refresh_mode値に基づいてリフレッシュを実行します。auto_refresh_modeのデフォルト値はALLです。 -
MAX_REFRESH_WINDOWプロパティが設定されている場合、Oracleは指定したウィンドウでリフレッシュを実行しようとします。リフレッシュが指定された制限を超えると、キャッシュ・リフレッシュは正常に終了し、残りの適格キャッシュは次のリフレッシュ・サイクルのためにキューに入れられます。 -
データベース内のすべての AUTOキャッシュは、Least Recently Used (LRU)に似た削除アルゴリズムを使用して管理されます。領域が不足している場合、最近アクセスされたキャッシュはリフレッシュ・プロセス中に自動的に削除され、ストレージ領域が解放されます。
GET_USER_PROPERTYプロシージャ
DBMS_CACHE.GET_USER_PROPERTYプロシージャを使用して、ユーザーの自動キャッシュ・プロパティを取得します。
構文
DBMS_CACHE.GET_USER_PROPERTY (
property_name IN VARCHAR2,
owner IN VARCHAR2 DEFAULT NULL,
property_value_str OUT VARCHAR2);
DBMS_CACHE.GET_USER_PROPERTY (
property_name IN VARCHAR2,
owner IN VARCHAR2 DEFAULT NULL,
property_value_num OUT NUMBER);パラメータ
| パラメータ | 摘要 |
|---|---|
property_name |
プロパティ名を指定します。
|
owner |
スキーマ名を指定します。このパラメータはオプションで、現在のスキーマにデフォルト設定されます。 |
property_value_str |
指定したプロパティ名のSTRING値を取り出します。 |
property_value_num |
指定されたプロパティ名のNUMBER値を取得します。 |
例
SET SERVEROUTPUT ON;
DECLARE
cache_property NUMBER;
BEGIN
DBMS_CACHE.GET_USER_PROPERTY (
property_name => 'MAX_CACHE_SIZE',
owner => NULL,
property_value => cache_property
);
DBMS_OUTPUT.PUT_LINE('MAX_CACHE_SIZE = ' || cache_property);
END;
/使用上のノート
- このプロシージャを実行するには、
ADMINユーザーとしてログインするか、DBMS_CACHEパッケージに対するEXECUTE権限を持っている必要があります。
SET_USER_PROPERTYプロシージャ
DBMS_CACHE.SET_USER_PROPERTYプロシージャを使用して、指定したスキーマのAUTOキャッシュ・プロパティ(スキーマの自動キャッシュを有効にするプロパティを含む)を設定します。このプロシージャはオーバーロードされています。
構文
DBMS_CACHE.SET_USER_PROPERTY (
property_name IN VARCHAR2,
property_value_num IN NUMBER,
owner IN VARCHAR2 DEFAULT NULL);
DBMS_CACHE.SET_USER_PROPERTY (
property_name IN VARCHAR2,
property_value_str IN NUMBER,
owner IN VARCHAR2 DEFAULT NULL
);パラメータ
| パラメータ | 摘要 |
|---|---|
property_name |
プロパティ名を指定します。
|
property_value_num |
指定されたプロパティ名のNUMBER値を指定します。 |
property_value_str |
指定されたプロパティ名のSTRING値を指定します。 |
owner |
スキーマ名を指定します。このパラメータはオプションで、現在のスキーマにデフォルト設定されます。 |
例
BEGIN
DBMS_CACHE.SET_USER_PROPERTY (
property_name => 'MAX_CACHE_SIZE',
property_value_num => 50,
owner => 'SALES');
END;
/使用上のノート
- このプロシージャを実行するには、
ADMINユーザーとしてログインするか、DBMS_CACHEパッケージに対するEXECUTE権限を持っている必要があります。