Autonomous Databaseでのタイムゾーン・ファイルの更新の管理

Autonomous Databaseには、Autonomous Databaseデータベース・インスタンスのタイムゾーン・ファイルを自動的に更新するためのオプションがいくつか用意されています。

タイム・ゾーン・ファイル更新オプションについて

タイムゾーンのサポートのために、Oracle Databaseでは、すべてのタイムゾーンのリストを格納するタイムゾーン・ファイルを使用します。Autonomous Databaseのタイムゾーン・ファイルは定期的に更新され、最新のタイムゾーン固有の変更が反映されます。

Autonomous Databaseには、タイム・ゾーン・ファイルを更新するための次のオプションがあります:

  • AUTO_DST_UPGRADE: タイム・ゾーン・ファイルを自動的にアップグレードし、データベース上のデータを自動的に更新して最新のタイム・ゾーン・データを使用します。このオプションでは、Autonomous Databaseインスタンスを再起動または停止してから起動する必要があります。

  • AUTO_DST_UPGRADE_EXCL_DATA: タイム・ゾーン・ファイルを自動的にアップグレードし、最新のタイム・ゾーン・データを使用するようにデータベース上のデータを自動的に更新しません。このオプションを有効にすると、タイムゾーン・ファイルが最新バージョンにアップグレードされ、バージョンは最新バージョンで最新の状態に保たれます。このオプションでは、Autonomous Databaseインスタンスを再起動する必要はありません。

ノート

デフォルトでは、AUTO_DST_UPGRADEAUTO_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タイム・ゾーン・ファイル・オプションの使用

Autonomous Databaseには、Autonomous Databaseデータベース・インスタンスのタイムゾーン・ファイルを自動的に更新するためのAUTO_DST_UPGRADEオプションが用意されています。

AUTO_DST_UPGRADE機能では、タイム・ゾーン・ファイルが自動的にアップグレードされ、データベース上の行が自動的にアップグレードされて、最新のタイム・ゾーン・データが使用されます。

ノート

デフォルトでは、AUTO_DST_UPGRADEAUTO_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を使用してタイムゾーン・ファイルの自動更新を有効にするには:

  1. AUTO_DST_UPGRADE機能を有効にします。
    BEGIN 
       DBMS_CLOUD_ADMIN.ENABLE_FEATURE(
            feature_name => 'AUTO_DST_UPGRADE');
    END;
    /
  2. dba_cloud_configを問い合せて、AUTO_DST_UPGRADEが有効になっていることを確認します。
    SELECT param_name, param_value FROM dba_cloud_config WHERE
           LOWER(param_name) = 'auto_dst_upgrade';
    
    PARAM_NAME              PARAM_VALUE                              
    ----------------------- ---------------------------------------- 
    auto_dst_upgrade        enable                                   
  3. dba_cloud_configを問い合せて、タイムゾーン・バージョンを確認します。
    SELECT param_name, param_value FROM dba_cloud_config 
        WHERE LOWER(param_name) = 'latest_timezone_version';
    
    PARAM_NAME              PARAM_VALUE 
    ----------------------- ----------- 
    latest_timezone_version 38          

    DB_NOTIFICATIONSビューを問い合せて、タイムゾーン・バージョンが最新バージョンかどうかを確認できます。

    SELECT type, time, description, expected_start_date FROM db_notifications 
       WHERE TYPE='TIMEZONE VERSION';

AUTO DST UPGRADEが有効な場合、Autonomous Databaseは最新バージョンのタイムゾーン・ファイルにアップグレードします(次回再起動するか、データベースを停止して起動します)。データ型がTIMESTAMP WITH TIME ZONEであるデータベースの列は、再起動時に新しいタイムゾーン・バージョンに変換されます。

AUTO_DST_UPGRADEを無効にするには:

  1. AUTO_DST_UPGRADE機能を無効にします。
    BEGIN 
       DBMS_CLOUD_ADMIN.DISABLE_FEATURE(
            feature_name => 'AUTO_DST_UPGRADE');
    END;
    /
  2. 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タイム・ゾーン・ファイル・オプションの使用

Autonomous Databaseには、Autonomous Databaseデータベース・インスタンスのタイムゾーン・ファイルを自動的に更新するためのAUTO_DST_UPGRADE_EXCL_DATAオプションが用意されています。

AUTO_DST_UPGRADE_EXCL_DATAは、タイム・ゾーン・ファイルを自動的にアップグレードし、最新のタイム・ゾーン・データを使用するようにデータベース上の行を自動的にアップグレードしません。このオプションを有効にすると、データベースは最新バージョンのタイム・ゾーン・ファイルにアップグレードし、その後、Autonomous Databaseメンテナンス・ウィンドウ中に新しいバージョンのタイム・ゾーン・ファイルを使用するようにデータベースをアップグレードします(新しいバージョンが使用可能な場合)。このオプションでは、Autonomous Databaseインスタンスを再起動する必要はありません。

ノート

デフォルトでは、AUTO_DST_UPGRADEAUTO_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を使用してタイムゾーン・ファイルの自動更新を有効にするには:

  1. AUTO_DST_UPGRADE_EXCL_DATA機能を有効にします。
    BEGIN 
       DBMS_CLOUD_ADMIN.ENABLE_FEATURE(
            feature_name => 'AUTO_DST_UPGRADE_EXCL_DATA');
    END;
    /
  2. 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';
    
    PARAM_NAME                   PARAM_VALUE                              
    ---------------------------- ---------------------------------------- 
    auto_dst_upgrade_excl_data    enabled                                   
  3. dba_cloud_configを問い合せて、タイムゾーン・バージョンを確認します。
    SELECT param_name, param_value FROM dba_cloud_config 
        WHERE LOWER(param_name) = 'latest_timezone_version';
    
    PARAM_NAME              PARAM_VALUE 
    ----------------------- ----------- 
    latest_timezone_version 38          

    DB_NOTIFICATIONSビューを問い合せて、タイムゾーン・バージョンが最新バージョンかどうかを確認できます。

    SELECT type, time, description, expected_start_date FROM db_notifications 
       WHERE TYPE='TIMEZONE VERSION';

AUTO_DST_UPGRADE_EXCL_DATAが有効な場合、Autonomous Databaseはタイム・ゾーン・ファイルの最新バージョンにアップグレードし、スケジュールされた各メンテナンス・ウィンドウ中に新しいタイム・ゾーン・ファイル・バージョンをチェックおよび更新します。AUTO_DST_UPGRADE_EXCL_DATAが有効な場合、データ型がTIMESTAMP WITH TIME ZONEであるデータベースの列は、新しいタイムゾーン・バージョンには変換されません。

AUTO_DST_UPGRADE_EXCL_DATAを無効にするには:

  1. AUTO_DST_UPGRADE_EXCL_DATA機能を無効にします。
    BEGIN 
       DBMS_CLOUD_ADMIN.DISABLE_FEATURE(
            feature_name => 'AUTO_DST_UPGRADE_EXCL_DATA');
    END;
    /
  2. 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データ型」を参照してください。