【SAP ABAP】ABAP7.4以降のS4HANAでの新構文(SELECT文)

登場人物紹介

三崎レイナ
社会人1年目。新卒でITコンサルティングファームに就職。初配属がSAPプロジェクトにアサインされる。SAPがわからないことだらけで悩んでいたところ、会社の先輩にSAPラボの所長を紹介され、毎週末に所長とSAPのお勉強中!

博士
SAPラボの所長。SAP大好き博士!SAP導入プロジェクトを構想策定~運用保守まであらゆるフェーズを数多く経験。
いまは優しきおじいちゃんだが、プロマネバリバリの時代はかなり怖かったらしい。現在は引退し、SAPの後進育成と啓蒙活動に従事中!

この記事を読むメリット

  • ABAP7.4以降のSELECT文についての新構文を理解することができます。

ABAP7.4以降ではSELECT文の書き方がだいぶ変わり、非常に便利になりました。
ネイティブSQLで直接データベースを触れたことがある方は分かると思いますが、それと近い感覚でSQL内で演算することができるようになっています。

博士

ここではSELECT文についての新構文を解説していくのじゃ!


※当記事ではABAP7.5以降の新構文も含みます。

・同じプログラム内で旧構文と新構文のSELECT文は同居可能です。
・1つのSELECT文の中では旧構文もしくは新構文のどちらかで記載する必要があります。

SAPフリーランスバンク SAPフリーランスバンク

新着のSAPフリーランス案件

【FI】

S/4HANAへのバージョンアップ支援(Jrコンサル可)

要スキル:
・FIの標準機能と会計業務に関する知識 ・FIのプロジェクトにおけるコンサルとしての業務経験 【尚可】 FI-AAの業務経験
月額単価:
~800,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
S/4HANAへバージョンアップに向けた、会計領域の要件定義を行っております。 要件定義後の移行設計や作業も行っていただく想定です。 ・現行の業務の整理 ・移行要件定義 ・現行のアドオン調査と設計 ・移行設計 ・移行作業 など

【PP】

メーカー向けSAP移行プロジェクト支援

要スキル:
・PPモジュールでのコンサルとしての業務経験 ・SAPプロジェクトにおける総合テストやユーザテストの対応経験 ・チームリーダーとしての経験
月額単価:
~1,500,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
ECCからS/4HANAへのバージョンアップを行っています。業務自体も見直し再構築する流れとなっており2026年の稼働に向けてプロジェクトが進んでおります。 ・インターフェース設計 ・ジョブ設計 ・総合テスト対応(不具合調査など含む) ・ユーザテスト対応(不具合調査など含む) など

【MM】

【SD】

製造業向けロジ領域の運用保守支援

要スキル:
・SDもしくはMMでのコンサルとしての業務経験 ・アドオン機能(ABAP)の調査経験 ・改善提案の経験
月額単価:
~900,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
フルモジュール稼働しているシステムにおける運用保守業務を担当頂きます。 ・顧客からのQA対応 ・不具合の調査や改善提案 ・顧客要望による機能拡張調査や実装~テスト など ※今後、S/4HANAへのバージョンアッププロジェクトも控えております。  そのプロジェクトにもアサイン頂く可能性がございます。

【BASIS】

【MM】

【SD】

製造業向け運用保守支援支援

要スキル:
・SDもしくはMMもしくはBASISでのコンサルとしての業務経験
月額単価:
~900,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
製造業のクライアント向けの運用保守業務を担当頂きます。 ・顧客からのQA対応 ・不具合の調査や改善提案 ・顧客要望による機能拡張調査や実装~テスト

【CO】

【FI】

【MM】

【PP】

【SD】

大手メーカー社向けSAP導入支援

要スキル:
・SAPコンサルとしてロジ領域もしくは会計領域での要件定義から本番稼働まで担当した経験
月額単価:
~1,400,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
複数の子会社を持つ大手メーカーでのSAP導入プロジェクトになります。 まずは数年かけ本社へのSAP導入を実施し、その後子会社へ展開する予定となります。 ・要件定義 ・プロトタイプの作成 ・アドオン設計 ・開発チームへの依頼や受け入れ等 ・総合テストやユーザテスト など

【FI】

商社向け基幹システムバージョン支援

要スキル:
(必須) SAP S/4HANA FIモジュールの保守開発経験(障害対応など) ABAP開発経験 (尚可) 商社関連案件の経験 リーダー経験
月額単価:
~1,000,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
SAPベースの基幹システムのバージョンアップ(S/4HANA1909⇒S/4HANA2023)に伴う調査を行っていただきます。 担当いただくモジュールはFIになります。機能毎の影響度や動作確認を行います。 また、SAP案件でのリーダー経験がある場合は上記のバージョンアップ調査ではなく 通常の保守チームにアサインいただく可能性もございます。(ユーザー窓口対応、問合せ調査・障害対応、マスタメンテナンス) バージョンアップ調査のチーム構成としては、SD、MM担当が1名、FI担当が1名となります。 そのため、基本的に1人称で調査を行い報告まで行っていただきます。 バージョンアップのスケジュール感 調査:2024年1月まで 実施:2024年2月から

【FI】

SAP運用業務支援

要スキル:
・SAPにおける運用保守経験(3年以上目安) ・FIまたはMMのユーザーとしての使用経験
月額単価:
~900,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
【作業概要】 現行SAP ECCからS/4 HANAへの移行試験が進行中です。 【作業内容】  現行SAP ECCのAA、FI、MMモジュールにおける運用業務  ・問合せ対応  ・障害対応  ・運用オペレーション

【FI】

SAP導入プロジェクト支援

要スキル:
・FI領域の要件定義書から基本設計書おこしの経験 ・顧客とのコミュニケーションして業務を進めた経験
月額単価:
~1,200,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
ロジ・会計領域をS/4HANAへ刷新に向けた会計領域の基本設計フェーズ作業を行っていただきます。

【FI】

光学機器 S/4HANA導入テスト支援

要スキル:
・FIコンサルとして要件定義~本稼働までの経験 ・FI(AP/AR)の機能、カスタマイズの知識 ・アドオン設計(開発除く)~各種テスト
月額単価:
~1,500,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
生産基幹システムのS/4新規導入プロジェクトです。 既存の会計システムとの連携→ロジデータを送信(AP/AR)と原価計算が対象となりUAT移行を担当頂きます。 スケジュール感:  2024年10月~2024年12月:結合テスト  2025年1月:UAT、移行  2025年2月:サービスパーツ 本稼働  2025年3月以降:展開

【CO】

一般消費財メーカーS/4 HANAバージョンアップ

要スキル:
<必須スキル> ・管理会計(CO)の全般の理解と実装経験、特にCO-PA(収益性分析)に関連した実装経験 ・顧客の業務要件の把握ととりまとめ、それに基づく実装方法検討、S/4での設定・カスタマイズ、アドオン要件の切り出し ・開発要件に関する基本設計、単体テスト仕様書作成、および単体テストの実施経験 ・SAPの予算機能に関する知見 ・課題に対する問題分析および解決策を的確に導いた経験 <あれば尚可> ・CO-PAの原価ベースから勘定ベースへの移行の経験 ・外部からの収益性データに関する取り込み経験 ・顧客が有しているSAP外のシステムとの関係性の整理、適切なソリューション検討経験 ・CO-PC(原価計算)、品目元帳の領域についての実装経験 ・原価周りに関する他モジュール(MM、PPなど)と原価との関わりについての知見
月額単価:
~1,600,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
<業務内容> ・CO-PA領域に関する業務要件の整理と定義書への取りまとめ ・基本設計書の作成 ・開発物の単体テスト受け入れ ・導入プロジェクトでの一連のテスト作業 ・データ移行に関する要件の取りまとめとデータ移行の実施
この記事のポイント

取得項目の指定 / 変数の指定の方法の変更

・新構文では取得項目は「,」を付けて指定します。
・内部テーブルや条件指定時の変数には、変数の頭に「@」を付けます

旧構文
* データ取得
SELECT ebeln
       bukrs
  FROM ekko
  INTO TABLE it_ekko
 WHERE ernam = l_user.
新構文
* データ取得
SELECT ebeln,
       bukrs
  FROM ekko
  INTO TABLE @it_ekko
 WHERE ernam = @l_user.

SELECT構文(記載順序)の追加

新構文では以下のような取得の仕方も可能となりました。

SELECT FROM テーブル名
FIELDS 項目1,項目2…
WHERE 項目 = @変数
INTO TABLE @内部テーブル

旧構文
SELECT ebeln
       bukrs
  FROM ekko
  INTO TABLE it_ekko
 WHERE ernam = l_user.
新構文
SELECT FROM ekko
     FIELDS ebeln,
            bukrs
      WHERE ernam = @l_user
 INTO TABLE @it_ekko.

UNION / UNION ALLの使用が可能に

新構文では、
・UNION / UNION ALLを用いて複数のSELECT文を一つの内部テーブルに格納することができます。
・UNION / UNION ALLを用いる際は「SELECT構文(記載順序)の追加」の構文を用い、格納先の内部テーブルは最後に一度だけ指定します。
・UNIONは重複削除され、UNION ALLは重複があってもそのまま内部テーブルにデータが格納されます。

旧構文
SELECT ebeln
       bukrs
  FROM ekko
  INTO TABLE it_ekko
 WHERE ernam = l_user1.

SELECT ebeln
       bukrs
  FROM ekko
  APPENDING TABLE it_ekko
 WHERE ernam = l_user2.
新構文
SELECT FROM ekko
     FIELDS ebeln,
            bukrs
      WHERE ernam = @l_user1
UNION
SELECT FROM ekko
     FIELDS ebeln,
            bukrs
      WHERE ernam = @l_user2
 INTO TABLE @it_ekko.

条件の左辺の演算が可能に

新構文では条件文(WHERE句)の左辺を演算して条件指定ができます。

新構文の例
SELECT FROM ztest_saplab
     FIELDS zkey1,
            zfltp1,
            zfltp2
        WHERE zint1 + zint2 < 10
   INTO TABLE @it_table.

テーブル項目以外を取得項目へ設定可能に

新構文ではテキストや変数を取得項目値として指定できるようになりました。

新構文の例
SELECT 'TEST'  AS field1,
       @l_text AS field2
  FROM ztest_saplab
  INTO TABLE @it_table.

演算した結果を取得項目へ設定可能に

新構文では計算した結果を取得項目値として指定できるようになりました。

新構文の例
SELECT 10 * 10        AS field1,
       zint1 + zint2  AS field2
  FROM ztest_saplab
  INTO TABLE @it_table.

内部テーブルからSELECT可能に

新構文ではDBテーブルからだけではなく内部テーブルからSELECTできるようになりました。

新構文の例
SELECT FROM @it_table AS TAB1 "内部テーブルから取得
     FIELDS ZKEY1
 INTO TABLE @it_table2.

新構文では内部テーブル・DBテーブルをJOINしたテーブルからSELECTも可能です。

新構文の例
SELECT FROM @it_table AS tab1
      INNER JOIN makt AS tab2
         ON tab1~zkey1 = tab2~maktx
     FIELDS tab1~zkey1
 INTO TABLE @it_table2.

サブクエリ(副問い合わせ)が利用可能に

新構文ではサブクエリ(副問い合わせ)も利用可能になりました。

SELECT matnr
  from mara
 where matnr in ( SELECT matnr
                    from makt
                   WHERE matnr = mara~matnr
                     and maktx = 'Frame' )
 INTO TABLE @data(it_mara).

さまざまな関数が利用可能に

新構文ではさまざまな関数を条件(WHERE句)や取得項目(FIELD句)に使用することができるようになりました。

新構文の例
SELECT FROM ztest_saplab
   FIELDS concat( ztext1 , ztext2 ) AS FIELD1,
          lower( ztext2 )           AS FIELD2,
          left( ztext3 , 4 )        AS FIELD3,
          CASE ztext3
            when '1' then 'GOOD'
            when '2' then 'BAD'
            ELSE 'NORMAL'
          END                       AS FIELD4
    WHERE concat( ztext1 , ztext2 ) = ztest_saplab~ztext3
     INTO TABLE @it_table.

関数一覧

使用できる関数を以下にまとめます。

数値関数

関数内容
ABS( field )fieldの絶対値。
CEIL( field )field以上の最小の整数に丸めた値。
DiV( field1,field2 )field1をfield2で除算した際の商(整数部分)。
DIVISION( field1,field2,dec )field1をfield2で除算して、dec(少数点の桁の位置)で四捨五入した値。
FLOOR( field )field以下の最大の整数に丸めた値。
MOD( field1,field2 )field1をfield2で除算した際の余り。
ROUND( field1,pos )field1をpos(少数点の桁の位置)で四捨五入した値。

文字列関数

関数内容
LEFT( field,len )fieldの左側から長さlenだけ切り出したの文字列。
RIGHT( field,len )fieldの右側から長さlenだけ切り出したの文字列。
LOWER( field )fieldを全て小文字に変換した文字列。
UPPER( field )fieldを全て大文字に変換した文字列。
INITCAP( field )fieldの単語の文字列の最初の文字を大文字に変換し、それ以外の文字を小文字に変換した文字列。
LENGTH( field )fieldの文字数。
SUBSTRING( field,pos,len )fieldから、文字の位置posから長さlenだけ切り出した文字列。
INSTR( field1,field2 )field1から文字列field2が最初に出現する位置。
REPLACE( field1,field2,field3 )field1の文字列に対し、field2をfield3に置換した文字列
CONCAT( field1,field2 )field1,field2を連結した文字列。
CONCAT_WITH_SPACE( field1,field2,len )field1,field2を長さlenのスペースを間に挟んで連結した文字列。
LTRIM( field,char )fieldの文字列の左側の文字charを削除した文字列。
RTRIM( field1,char )fieldの文字列の右側の文字charを削除した文字列。
LPAD( field1,len,field2 )field1を長さlenだけ切り出した文字列。
その際、長さlenに満たない場合は左側に文字列field2を埋めた文字列となる。
RPAD( field1,len,field2 )field1を長さlenだけ切り出した文字列。
その際、長さlenに満たない場合は右側に文字列field2を埋めた文字列となる。

条件の関数

関数内容
CASE field1
WHEN value1
THEN return1
WHEN value2
THEN return2

ELSE
return3
END
field1の値が、
・value1の時にreturn1を返す。
・value2の時にreturn2を返す。

・上記以外の時にreturn3を返す。
CASE
WHEN cond1
THEN return1
WHEN cond2
THEN return2

ELSE
return3
END
・条件式cond1が正の時にreturn1を返す。
・条件式cond2が正の時にreturn2を返す。

・上記以外の時にreturn3を返す。
※上に記載している条件が優先される。
COALESCE( field1,field2,field3,… )field1,field2,field3…のうち、最初にNULLではない値を返す。
博士

SELECTに関するABAP7.4以降の新構文についての解説は以上じゃ。
まだ新構文はあるので、都度更新していくぞい!

新着のSAPフリーランス案件

【FI】

S/4HANAへのバージョンアップ支援(Jrコンサル可)

要スキル:
・FIの標準機能と会計業務に関する知識 ・FIのプロジェクトにおけるコンサルとしての業務経験 【尚可】 FI-AAの業務経験
月額単価:
~800,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
S/4HANAへバージョンアップに向けた、会計領域の要件定義を行っております。 要件定義後の移行設計や作業も行っていただく想定です。 ・現行の業務の整理 ・移行要件定義 ・現行のアドオン調査と設計 ・移行設計 ・移行作業 など

【PP】

メーカー向けSAP移行プロジェクト支援

要スキル:
・PPモジュールでのコンサルとしての業務経験 ・SAPプロジェクトにおける総合テストやユーザテストの対応経験 ・チームリーダーとしての経験
月額単価:
~1,500,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
ECCからS/4HANAへのバージョンアップを行っています。業務自体も見直し再構築する流れとなっており2026年の稼働に向けてプロジェクトが進んでおります。 ・インターフェース設計 ・ジョブ設計 ・総合テスト対応(不具合調査など含む) ・ユーザテスト対応(不具合調査など含む) など

【MM】

【SD】

製造業向けロジ領域の運用保守支援

要スキル:
・SDもしくはMMでのコンサルとしての業務経験 ・アドオン機能(ABAP)の調査経験 ・改善提案の経験
月額単価:
~900,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
フルモジュール稼働しているシステムにおける運用保守業務を担当頂きます。 ・顧客からのQA対応 ・不具合の調査や改善提案 ・顧客要望による機能拡張調査や実装~テスト など ※今後、S/4HANAへのバージョンアッププロジェクトも控えております。  そのプロジェクトにもアサイン頂く可能性がございます。

【BASIS】

【MM】

【SD】

製造業向け運用保守支援支援

要スキル:
・SDもしくはMMもしくはBASISでのコンサルとしての業務経験
月額単価:
~900,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
製造業のクライアント向けの運用保守業務を担当頂きます。 ・顧客からのQA対応 ・不具合の調査や改善提案 ・顧客要望による機能拡張調査や実装~テスト

【CO】

【FI】

【MM】

【PP】

【SD】

大手メーカー社向けSAP導入支援

要スキル:
・SAPコンサルとしてロジ領域もしくは会計領域での要件定義から本番稼働まで担当した経験
月額単価:
~1,400,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
複数の子会社を持つ大手メーカーでのSAP導入プロジェクトになります。 まずは数年かけ本社へのSAP導入を実施し、その後子会社へ展開する予定となります。 ・要件定義 ・プロトタイプの作成 ・アドオン設計 ・開発チームへの依頼や受け入れ等 ・総合テストやユーザテスト など

【FI】

商社向け基幹システムバージョン支援

要スキル:
(必須) SAP S/4HANA FIモジュールの保守開発経験(障害対応など) ABAP開発経験 (尚可) 商社関連案件の経験 リーダー経験
月額単価:
~1,000,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
SAPベースの基幹システムのバージョンアップ(S/4HANA1909⇒S/4HANA2023)に伴う調査を行っていただきます。 担当いただくモジュールはFIになります。機能毎の影響度や動作確認を行います。 また、SAP案件でのリーダー経験がある場合は上記のバージョンアップ調査ではなく 通常の保守チームにアサインいただく可能性もございます。(ユーザー窓口対応、問合せ調査・障害対応、マスタメンテナンス) バージョンアップ調査のチーム構成としては、SD、MM担当が1名、FI担当が1名となります。 そのため、基本的に1人称で調査を行い報告まで行っていただきます。 バージョンアップのスケジュール感 調査:2024年1月まで 実施:2024年2月から

【FI】

SAP運用業務支援

要スキル:
・SAPにおける運用保守経験(3年以上目安) ・FIまたはMMのユーザーとしての使用経験
月額単価:
~900,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
【作業概要】 現行SAP ECCからS/4 HANAへの移行試験が進行中です。 【作業内容】  現行SAP ECCのAA、FI、MMモジュールにおける運用業務  ・問合せ対応  ・障害対応  ・運用オペレーション

【FI】

SAP導入プロジェクト支援

要スキル:
・FI領域の要件定義書から基本設計書おこしの経験 ・顧客とのコミュニケーションして業務を進めた経験
月額単価:
~1,200,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
ロジ・会計領域をS/4HANAへ刷新に向けた会計領域の基本設計フェーズ作業を行っていただきます。

【FI】

光学機器 S/4HANA導入テスト支援

要スキル:
・FIコンサルとして要件定義~本稼働までの経験 ・FI(AP/AR)の機能、カスタマイズの知識 ・アドオン設計(開発除く)~各種テスト
月額単価:
~1,500,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
生産基幹システムのS/4新規導入プロジェクトです。 既存の会計システムとの連携→ロジデータを送信(AP/AR)と原価計算が対象となりUAT移行を担当頂きます。 スケジュール感:  2024年10月~2024年12月:結合テスト  2025年1月:UAT、移行  2025年2月:サービスパーツ 本稼働  2025年3月以降:展開

【CO】

一般消費財メーカーS/4 HANAバージョンアップ

要スキル:
<必須スキル> ・管理会計(CO)の全般の理解と実装経験、特にCO-PA(収益性分析)に関連した実装経験 ・顧客の業務要件の把握ととりまとめ、それに基づく実装方法検討、S/4での設定・カスタマイズ、アドオン要件の切り出し ・開発要件に関する基本設計、単体テスト仕様書作成、および単体テストの実施経験 ・SAPの予算機能に関する知見 ・課題に対する問題分析および解決策を的確に導いた経験 <あれば尚可> ・CO-PAの原価ベースから勘定ベースへの移行の経験 ・外部からの収益性データに関する取り込み経験 ・顧客が有しているSAP外のシステムとの関係性の整理、適切なソリューション検討経験 ・CO-PC(原価計算)、品目元帳の領域についての実装経験 ・原価周りに関する他モジュール(MM、PPなど)と原価との関わりについての知見
月額単価:
~1,600,000円 / 月
稼働場所:
東京都
稼働率:
100%
作業内容:
<業務内容> ・CO-PA領域に関する業務要件の整理と定義書への取りまとめ ・基本設計書の作成 ・開発物の単体テスト受け入れ ・導入プロジェクトでの一連のテスト作業 ・データ移行に関する要件の取りまとめとデータ移行の実施

★★★SAPラボのライター募集★★★

SAPラボでは、SAPの知識を活かして副業をしたい方を募集してるのじゃ!

SAPラボのライターの特徴

・ライティング初心者OK!
・報酬高単価!
・業務委託契約なので副業として最適!

SAP記事執筆者としての活動実績として利用可能なので、転職時や案件探しの際に企業へのアピール材料にもなります。

募集要項

・SAP導入や運用保守プロジェクトへの参画経験1年以上

ご応募/お問合せ先

info@sap-labo.com

少しでもご興味ある方、ぜひお気軽にご連絡下さい!

よかったらシェアしてね!
  • URLをコピーしました!

この記事を書いた人

株式会社Luxy(https://luxy-inc.com/company_info/)と株式会社アガルートITパートナーズ(https://agaroot-itp.com/about/)の代表取締役。

新卒でSAPエンジニアとして働き始める。副業で事業を開始したのち、2015年に独立しシステム開発会社を設立。SAPの案件に従事しつつシステム開発事業を成長させ、2021年に会社をバイアウト。その後も創業会社とグループ会社で代表を兼任。
SAPエンジニア・コンサルタント歴は10年以上。

一緒に「SAPラボ」を盛り上げてくれる副業ライター(SAP経験者)を募集してますので、お問い合わせよりお願いします!

この記事のポイント