SAPABAP-日付と時刻

ABAPは、世界中のほとんどで有効なグレゴリオ暦を暗黙的に参照します。出力を国固有のカレンダーに変換できます。日付は、カレンダーに関して正確な日、週、または月に指定された時刻です。時間は、1日に対して正確な秒または分に指定されます。ABAPは、常に24時間形式で時間を節約します。出力は国固有の形式にすることができます。日付と時刻は通常、現在のタイムゾーンで有効なローカル日付として解釈されます。

ABAPには、日付と時刻を処理するための2つの組み込みタイプが用意されています-

  • Dデータ型
  • Tデータ型

以下は基本的なフォーマットです-

DATA: date TYPE D, 
      time TYPE T.  
	
DATA: year TYPE I, 
month TYPE I,  
day TYPE I, 
hour TYPE I,  
minute TYPE I, 
second TYPE I.

これらのタイプは両方とも、それぞれYYYYMMDDおよびHHMMSSの形式を持つ固定長の文字タイプです。

タイムスタンプ

これらの組み込みタイプに加えて、他の2つのタイプ TIMESTAMP そして TIMESTAMPLタイムスタンプをUTC形式で保存するために、多くの標準アプリケーションテーブルで使用されています。次の表は、ABAPで使用可能な基本的な日付と時刻のタイプを示しています。

S.No. データ型と説明
1

D

YYYYMMDD形式の組み込みの固定長日付型。たとえば、値20100913は、2010年9月13日の日付を表します。

2

T

HHMMSS形式の組み込みの固定長時間タイプ。たとえば、値102305は時刻10:23:05 AMを表します。

3

TIMESTAMP (タイプP –長さ8小数点なし)

このタイプは、YYYYMMDDhhmmss形式で短いタイムスタンプを表すために使用されます。たとえば、値20100913102305は、2010年9月13日の午前10:23:05の日付を表します。

4

TIMESTAMPL (タイプP-長さ11の小数7)

TIMESTAMPLは、長いタイムスタンプをYYYYMMDDhhmmss、mmmuuun形式で表します。ここで、追加の数字「mmmuuun」は秒の端数を表します。

現在の日時

次のコードスニペットは、現在のシステムの日付と時刻を取得します。

REPORT YR_SEP_15. 
DATA: date_1 TYPE D. 

date_1 = SY-DATUM. 
Write: / 'Present Date is:', date_1 DD/MM/YYYY. 

date_1 = date_1 + 06. 
Write: / 'Date after 6 Days is:', date_1 DD/MM/YYYY.

上記のコードは次の出力を生成します-

Present Date is: 21.09.2015 
Date after 6 Days is: 27.09.2015

変数date_1には、現在のシステム日付SY-DATUMの値が割り当てられます。次に、日付値を6ずつインクリメントします。ABAPでの日付計算に関して、これは、日付オブジェクトの日コンポーネントを6日増やしていることを意味します。ABAPランタイム環境は、月末に達するたびに日付値をロールオーバーするのに十分スマートです。

時間の計算は、日付の計算と同様に機能します。次のコードは、基本的な時間演算を使用して、現在のシステム時間を75秒インクリメントします。

REPORT YR_SEP_15. 
DATA: time_1 TYPE T. 
      time_1 = SY-UZEIT. 

Write /(60) time_1 USING EDIT MASK 
'Now the Time is: __:__:__'. 
time_1 = time_1 + 75. 

Write /(60) time_1 USING EDIT MASK 
'A Minute and a Quarter from Now, it is: __:__:__'.

上記のコードは次の出力を生成します-

Now the Time is 11:45:05 
A Minute and a Quarter from Now, it is: 11:46:20

タイムスタンプの操作

現在のシステム時刻を取得し、を使用してタイムスタンプ変数に格納できます。 GET TIME STAMP次のコードに示すように。GET TIME STAMPステートメントは、使用されるタイムスタンプデータオブジェクトのタイプに応じて、タイムスタンプをロングハンド形式またはショートハンド形式で格納します。タイムスタンプ値は、UTC標準を使用してエンコードされます。

REPORT YR_SEP_12. 
DATA: stamp_1 TYPE TIMESTAMP,
 
stamp_2 TYPE TIMESTAMPL. 
GET TIME STAMP FIELD stamp_1. 
Write: / 'The short time stamp is:', stamp_1 

TIME ZONE SY-ZONLO. 
GET TIME STAMP FIELD stamp_2. 
Write: / 'The long time stamp is:', stamp_2 
TIME ZONE SY-ZONLO.

上記のコードは次の出力を生成します-

The short time stamp is: 18.09.2015 11:19:40 
The long time stamp is: 18.09.2015 11:19:40,9370000

上記の例では、WRITEステートメントのTIMEZONE追加を使用してタイムスタンプを表示しています。この追加により、指定されたタイムゾーンのルールに従ってタイムスタンプの出力がフォーマットされます。システムフィールドSY-ZONLOは、ユーザーの設定で設定されたローカルタイムゾーンを表示するために使用されます。