Autonomous Databaseでのタイムゾーン・ファイルの更新の管理
- タイムゾーンのファイルの更新オプションについて
タイムゾーンのサポートのためにOracle Databaseでは、すべてのタイムゾーンのリストを格納するタイムゾーン・ファイルを使用します。Autonomous Databaseのタイムゾーン・ファイルは定期的に更新され、最新のタイムゾーン固有の変更が反映されます。 - AUTO_DST_UPGRADEタイム・ゾーン・ファイル・オプションの使用
Autonomous Databaseには、Autonomous Databaseデータベース・インスタンスのタイム・ゾーン・ファイルを自動的に更新するためのAUTO_DST_UPGRADE
オプションが用意されています。 - AUTO_DST_UPGRADE_EXCL_DATAタイム・ゾーン・ファイル・オプションの使用
Autonomous Databaseには、Autonomous Databaseデータベース・インスタンスのタイム・ゾーン・ファイルを自動的に更新するためのAUTO_DST_UPGRADE_EXCL_DATA
オプションが用意されています。
親トピック: サービスの管理
タイム・ゾーン・ファイルの更新オプションについて
タイムゾーンのサポートのため、Oracle Databaseでは、すべてのタイムゾーンのリストを格納するタイムゾーン・ファイルを使用します。Autonomous Databaseのタイムゾーン・ファイルは定期的に更新され、最新のタイムゾーン固有の変更が反映されます。
Autonomous Databaseには、タイムゾーン・ファイルを更新するための次のオプションがあります:
-
AUTO_DST_UPGRADE
: タイム・ゾーン・ファイルを自動的にアップグレードし、最新のタイム・ゾーン・データを使用するようにデータベース上のデータを自動的に更新します。このオプションでは、Autonomous Databaseインスタンスを再起動または停止してから起動する必要があります。 -
AUTO_DST_UPGRADE_EXCL_DATA
: タイム・ゾーン・ファイルを自動的にアップグレードし、最新のタイム・ゾーン・データを使用するようにデータベース上のデータを自動的に更新しません。このオプションを有効にすると、タイムゾーン・ファイルが最新バージョンにアップグレードされ、バージョンが最新バージョンに保たれます。このオプションでは、Autonomous Databaseインスタンスを再起動する必要はありません。
デフォルトでは、
AUTO_DST_UPGRADE
とAUTO_DST_UPGRADE_EXCL_DATA
の両方が無効になっています。これらのオプションのいずれか一方を有効にできますが、両方を有効にすることはできません。
すべての夏時間(DST)バージョン・リリースでは、既存のデータを最新のDSTルールに準拠させるために、DSTファイルの変更が導入されています。データベースのタイム・ゾーン・ファイルへの変更の適用は、新しいデータの処理方法に影響するだけでなく、TIMESTAMP WITH TIME ZONE
列に格納されているデータが変更される可能性があります。
ロードまたはインポート操作で次のタイム・ゾーン関連のエラーが発生した場合、これはタイム・ゾーン・ファイルのバージョンが古く、データベースで使用可能な最新バージョンに更新する必要があることを示します。
ORA-39405: Oracle Data Pump does not support importing from a source database with TSTZ version y
into a target database with TSTZ version n.
AUTO_DST_UPGRADE
機能を有効にすると、使用可能な最新バージョンのタイム・ゾーン・ファイルを使用するようにインスタンスが自動的にアップグレードされ、最新のタイム・ゾーン・データを使用するようにデータベースの行が自動的に更新されます。タイム・ゾーン・ファイルの最新バージョンが適用され、TIMESTAMP WITH TIME ZONE
列の値は次回のデータベース再起動時に更新されます。ただし、データベースの使用状況によっては、必要なデータベース再起動によって、AUTO_DST_UPGRADE
を使用して最新のタイム・ゾーン・ファイルにアップグレードできない場合があります。
AUTO_DST_UPGRADE_EXCL_DATA
を有効にして、タイムゾーン・ファイルを更新できます。このオプションを使用すると、タイムゾーン・ファイルのバージョンの不一致が原因でインポート/エクスポート・エラーが発生した場合(ORA-3940
エラーが発生した場合)に、すぐにデータベースを更新できます。
データベースでAUTO_DST_UPGRADE_EXCL_DATA
を有効にすると、次の場合に役立ちます。
-
インスタンス上のデータはUTCにあり、データベースはDSTタイムゾーン・ファイルの更新の影響を受けません。
-
インスタンスには、
TIMESTAMP WITH TIME ZONE
列にデータがありません。 -
インスタンスのデータでは、新しいタイム・ゾーンまたは夏時間ポリシーで変更されない日付が使用されます。
この場合、Autonomous Databaseインスタンスに新しいタイムゾーン・ルールによって悪影響を受ける行が含まれず、ORA-3940
エラーが発生した場合は、AUTO_DST_UPGRADE_EXCL_DATA
オプションを有効にして、最新バージョンのタイムゾーン・ファイルに更新できます。AUTO_DST_UPGRADE_EXCL_DATA
オプションは、DSTの変更によるデータの一貫性の問題に対して、Oracle Data Pumpジョブの成功を優先します。
タイムゾーンの変更がデータベースに影響を与えるかどうかを判断するには、Oracle Supportドキュメント406410.1を参照してください。
Oracleでは、これらの制限ケースがデータベースに適用されない場合に、
AUTO_DST_UPGRADE
オプションを有効にすることをお薦めします。
要約すると、AUTO_DST_UPGRADE
またはAUTO_DST_UPGRADE_EXCL_DATA
で自動タイムゾーン・アップグレードを有効にする選択には、次の考慮事項があります。
-
考えられるデータの不整合: Oracleでは、
AUTO_DST_UPGRADE
を有効にして、データベースを最新のタイムゾーン・ファイル・バージョンでメンテナンスすることをお薦めします。このオプションでは、最新のタイム・ゾーン・データを使用するようにデータベースの行が自動的に更新されます。AUTO_DST_UPGRADE_EXCL_DATA
という代替オプションを使用すると、データベースを再起動することなく、最新のタイムゾーン・バージョンを使用してデータベースをメンテナンスできます。ただし、更新されたタイムゾーン・ファイルの影響を受けるデータは更新されず、データの不整合が発生する可能性があります。 -
データベースの再起動: Oracleでは、
AUTO_DST_UPGRADE
を有効にして、最新のタイムゾーン・ファイル・バージョンでデータベースをメンテナンスすることをお薦めします。このオプションでは、最新のタイムゾーン・ファイル・バージョンにアップグレードするために再起動が必要であり、再起動時に、TIMESTAMP WITH TIME ZONE
データ型の既存のデータの行が最新バージョンを使用するように更新されます。AUTO_DST_UPGRADE
を有効にすると、データベースの再起動時間に影響する可能性があります。新しいタイム・ゾーン・ファイルが存在し、データベースの再起動時に更新する必要があるデータがある場合、このオプションを有効にしないと、再起動に余分な時間がかかることがあります。AUTO_DST_UPGRADE_EXCL_DATA
を有効にすると、このオプションを有効にすると、データベースは最新バージョンのタイムゾーン・ファイルにアップグレードされ、メンテナンス・ウィンドウごとに新しいタイムゾーン・ファイルが使用可能な場合、Autonomous Databaseは最新バージョンを使用するようにデータベースを更新します。AUTO_DST_UPGRADE_EXCL_DATA
を有効にしても、Autonomous Databaseインスタンスを再起動して、最新バージョンのタイムゾーン・ファイルを最新の状態に保つ必要はありません。
詳細は、「日時データ型とタイム・ゾーン・サポート」を参照してください。
AUTO_DST_UPGRADEタイムゾーン・ファイル・オプションの使用
AUTO_DST_UPGRADE
オプションが用意されています。
AUTO_DST_UPGRADE
機能は、タイム・ゾーン・ファイルを自動的にアップグレードし、最新のタイム・ゾーン・データを使用するようにデータベース上の行を自動的にアップグレードします。
デフォルトでは、
AUTO_DST_UPGRADE
とAUTO_DST_UPGRADE_EXCL_DATA
の両方が無効になっています。自動タイムゾーン・ファイルの更新オプションのいずれか一方を有効にできますが、両方は有効にできません。
AUTO_DST_UPGRADE
を有効にすると、インスタンスの状態に応じて、Autonomous Databaseインスタンスはタイム・ゾーン・ファイルの更新を自動的に適用します:
-
停止: 次の起動操作で、更新が自動的に適用されます。
-
利用可能: 再起動後、または停止してから開始すると、更新が自動的に適用されます。
ロードまたはインポート操作で次のタイム・ゾーン関連のエラーが発生した場合、これはタイム・ゾーン・ファイルが古く、データベースで使用可能な最新バージョンに更新する必要があることを示します。
ORA-39405: Oracle Data Pump does not support importing from a source database with TSTZ version n+1
into a target database with TSTZ version n.
AUTO_DST_UPGRADE
を使用してタイムゾーン・ファイルの自動更新を有効にするには:
AUTO DST UPGRADE
が有効な場合、Autonomous Databaseは最新バージョンのタイム・ゾーン・ファイル(次回再起動時、またはデータベースを停止してから起動時)にアップグレードします。データ型がTIMESTAMP WITH TIME ZONE
であるデータベースの列は、再起動時に新しいタイムゾーン・バージョンに変換されます。
AUTO_DST_UPGRADE
を無効にするには:
AUTO_DST_UPGRADE
機能を無効にします。BEGIN
DBMS_CLOUD_ADMIN.DISABLE_FEATURE
( feature_name => 'AUTO_DST_UPGRADE'); END; /-
dba_cloud_config
を問い合せて、AUTO_DST_UPGRADE
が無効になっていることを確認します。SELECT param_name, param_value FROM dba_cloud_config WHERE LOWER(param_name) = 'auto_dst_upgrade'; 0 rows selected.
詳細は、ENABLE_FEATUREプロシージャおよびDISABLE_FEATUREプロシージャを参照してください。
詳細は、「TIMESTAMP WITH TIME ZONEデータ型」を参照してください。
AUTO_DST_UPGRADE_EXCL_DATAタイムゾーン・ファイル・オプションの使用
AUTO_DST_UPGRADE_EXCL_DATA
オプションが用意されています。
AUTO_DST_UPGRADE_EXCL_DATA
は、タイム・ゾーン・ファイルを自動的にアップグレードし、最新のタイム・ゾーン・データを使用するようにデータベース上の行を自動的にアップグレードしません。このオプションを有効にすると、データベースは最新バージョンのタイムゾーン・ファイルにアップグレードされ、その後、Autonomous Databaseのメンテナンス・ウィンドウ中に新しいバージョンのタイムゾーン・ファイルを使用するようにデータベースをアップグレードします(新しいバージョンが使用可能な場合)。このオプションでは、Autonomous Databaseインスタンスを再起動する必要はありません。
デフォルトでは、
AUTO_DST_UPGRADE
とAUTO_DST_UPGRADE_EXCL_DATA
の両方が無効になっています。自動タイムゾーン・ファイルの更新オプションのいずれか一方を有効にできますが、両方は有効にできません。
ロードまたはインポート操作で次のタイム・ゾーン関連のエラーが発生した場合、これはタイム・ゾーン・ファイルが古く、データベースで使用可能な最新バージョンに更新する必要があることを示します。
ORA-39405: Oracle Data Pump does not support importing from a source database with TSTZ version n+1
into a target database with TSTZ version n.
AUTO_DST_UPGRADE_EXCL_DATA
を使用してタイムゾーン・ファイルの自動更新を有効にするには:
AUTO_DST_UPGRADE_EXCL_DATA
が有効な場合、Autonomous Databaseは最新バージョンのタイムゾーン・ファイルにアップグレードし、スケジュールされた各メンテナンス・ウィンドウ中に新しいタイムゾーン・ファイル・バージョンをチェックおよび更新します。AUTO_DST_UPGRADE_EXCL_DATA
が有効な場合、データ型がTIMESTAMP WITH TIME ZONE
であるデータベースの列は、新しいタイムゾーン・バージョンに変換されません。
AUTO_DST_UPGRADE_EXCL_DATA
を無効にするには:
AUTO_DST_UPGRADE_EXCL_DATA
機能を無効にします。BEGIN
DBMS_CLOUD_ADMIN.DISABLE_FEATURE
( feature_name => 'AUTO_DST_UPGRADE_EXCL_DATA'); END; /-
dba_cloud_config
を問い合せて、AUTO_DST_UPGRADE_EXCL_DATA
が無効になっていることを確認します。SELECT param_name, param_value FROM dba_cloud_config WHERE LOWER(param_name) = 'auto_dst_upgrade_excl_data'; 0 rows selected.
詳細は、ENABLE_FEATUREプロシージャおよびDISABLE_FEATUREプロシージャを参照してください。
詳細は、「TIMESTAMP WITH TIME ZONEデータ型」を参照してください。