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データ型」を参照してください。