【SAP ABAP】汎用モジュール(Function Module)の概要と作成方法

登場人物紹介

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

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

この記事を読むメリット

  • 汎用モジュールと汎用グループの概要が理解できます。
  • 汎用モジュールを作成することができるようになります。
  • プログラムから汎用モジュールを呼び出せるようになります。
レイナ

汎用モジュールはどういうもので、どうやって作成したらいいんだろう?

SAPの汎用モジュール(Function Module)はABAPでコーディングされる共通機能です。

当記事では基本知識となる汎用モジュールの概要と汎用モジュールの作成方法について解説していきますね。
アドオン機能の設計や開発に関わるメンバーであれば必ず知っておくべき事項なので、もし知らない方は要チェックです!

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領域に関する業務要件の整理と定義書への取りまとめ ・基本設計書の作成 ・開発物の単体テスト受け入れ ・導入プロジェクトでの一連のテスト作業 ・データ移行に関する要件の取りまとめとデータ移行の実施
この記事のポイント

汎用モジュールとは?

汎用モジュールとは、複数の異なるプログラムから呼び出して使用できる共通部品(関数)です。
複数の機能にて、同じロジックの処理をしたいという要件が発生することがあります。そんな時に汎用モジュールを利用します。

汎用モジュールの概要

汎用モジュールの基本的な機能としては、大きく分けて以下の3つとなります。

  • 呼び出し元プログラムからパラメータを受け取り
  • 主処理
    トランザクションデータ登録・DB直接更新・ファイルアウトプットなどの何かしらの処理
  • 呼び出し元プログラムへパラメータを受け渡し

例えば、複数の機能で「単価」と「個数」から「合計金額」を計算したいという要件があったとします。その場合は

  • 呼び出し元のプログラムから「単価」と「個数」を受け取り
  • 「単価」と「個数」を掛けて「合計金額」を算出
  • 呼び出し元プログラムへ「合計金額」を受け渡し

という汎用モジュールを作成することで、複数の機能から汎用モジュールを呼び出すことで同じ計算結果を利用することができます。

汎用モジュールの具体例

共通部品(関数)としては、汎用モジュールだけではなくT-CODE:SE24でクラスを定義・作成することも可能です。クラスについては別途解説します!

汎用グループとは?

汎用グループとは一般的に、汎用モジュールを利用目的ごとに取りまとめるグループです。
汎用モジュールは必ず1つの汎用グループに紐付ける必要があります。
※1つの汎用モジュールには複数の汎用モジュールが紐付く構成となります。

汎用グループの概要

汎用グループ内にある汎用モジュールは、変数や内部テーブルなどの定義を共通で利用することができます。

汎用モジュールの作成方法

汎用モジュールを作成する際はT-CODE:SE37を使用します。

汎用グループの登録

まずは汎用グループを登録します。
※既存の汎用グループに汎用モジュールを紐付ける場合は省略可能です。

T-CODE:SE37のヘッダメニューの「ジャンプ > 汎用グループ > グループ登録」を選択し、汎用グループIDと名称(内容説明)を入力して登録します。

汎用グループの登録

汎用モジュールの登録

T-CODE:SE37から登録したい汎用モジュールIDを入力し、「登録」ボタンを押下します。

ポップアップ画面にて紐付ける汎用グループと汎用モジュールの説明文を入力します。

汎用グループの作成(汎用モジュールIDの指定)

次にインポートパラメータ/エクスポートパラメータを入力します。※いずれも仕様により不要な場合もあります。
インポートパラメータの「任意」にチェックをいれるとプログラムから汎用モジュールを呼び出す際にパラメータの指定は必須ではなくなります。

汎用グループの作成(インポートパラメータの設定)
汎用グループの作成(エクスポートパラメータの設定)

インポート/エクスポートパラメータ以外にも以下のパラメータを指定することもできます。

汎用グループの作成(CHANGING/テーブル/例外の設定)
  • CHANGINGパラメータ
    呼び出し元のプログラムから渡された変数やテーブルを汎用モジュール内で編集し、呼び出し元のプログラムに返します。
  • テーブルパラメータ
    呼び出し元のプログラムから渡されたテーブルを汎用モジュール内で編集し、呼び出し元のプログラムに返します。
  • 例外パラメータ
    汎用モジュール内で意図しない処理がされた場合などに例外を返します。
    例外が返された際には、呼び出し元プログラム上ではシステム変数:SY-SUBRCに例外番号が設定されます。

以下では例外パラメータで個数(kosu)が0だった場合は「KOSU_ERROR」という例外を出力する例となります。

汎用グループの作成(例外の設定)

次に、ソースコードタブにて処理したい内容をABAPで記述します。

以下の例では個数(kosu)が0だった場合は例外を返し、0以外だった場合は合計金額(goukei_kingaku)に単価(tanka)×個数(kosu)を設定する内容を記述しています。

汎用グループの作成(ソースコードの記載)

以下は上図のプログラム部分をテキストで記載したものです。

FUNCTION ztest_satofn01. " 作成した汎用モジュール名
*"----------------------------------------------------------------------
*"*"ローカルインタフェース:
*"  IMPORTING
*"     REFERENCE(TANKA) TYPE  PRICE
*"     REFERENCE(KOSU) TYPE  AMNT
*"  EXPORTING
*"     REFERENCE(GOUKEI_KINGAKU) TYPE  TOTAL_KK
*"  EXCEPTIONS
*"      KOSU_ERROR
*"----------------------------------------------------------------------

* 個数が0の場合は例外を返す
  IF kosu = 0.
    RAISE kosu_error.
  ENDIF.

* 合計金額を計算する
  goukei_kingaku = tanka * kosu.

ENDFUNCTION.

構文チェックしてエラーが無ければ有効化をしてみましょう!
その際に汎用グループを登録した際に自動で登録されるプログラムも一緒に選択して有効化しましょう。

汎用モジュールの単体テスト

先ほど作った汎用モジュールをテストしてみましょう。
T-CODE:SE37から作成した汎用モジュールを指定し実行ボタンを押下します。

汎用グループの実行方法

次にインポートパラメータを指定し実行します。

以下は個数(kosu)に0を入れて例外が返される確認です。

汎用グループの実行方法(例外処理されるパラメータの設定)

次に個数(kosu)に0以外を入れて合計金額(goukei_kingaku)が計算されるかの確認です。

汎用グループの実行方法(正常処理されるパラメータの設定)

汎用モジュールをプログラムから呼び出す

プログラムから汎用モジュールを呼び出す方法も解説をします。
ここではT-CODE:SE38にてABAPプログラムの中から汎用モジュールを呼び出してみましょう。

博士

T-CODE:SE38でプログラムを作成する方法は以下で確認できるぞい!

パターンボタンを押下し、CALL FUNCTIONにて先ほど作成した汎用モジュールを入力してENTERを押下してみましょう。

するとプログラム内に汎用モジュールと定義されたパラメータが記述されたソースコードのフォーマットが自動入力されます。

プログラムから汎用モジュールのフォーマットを呼び出す方法

以下は上記のフォーマットを編集し、単価(tanka)が100・個数(kosu)が9を汎用モジュールに渡して合計金額(goukei_kingaku)を出力する例です。

プログラムから汎用モジュールを呼び出し編集

以下は上図のプログラム部分をテキストで記載したものです。

REPORT ztest_sato18. " 作成したプログラム名

* 変数定義
DATA
  g_goukei_kingaku TYPE total_kk. "合計金額

* 汎用モジュール
CALL FUNCTION 'ZTEST_SATOFN01' " 作成した汎用モジュール名
  EXPORTING
    tanka          = 100
    kosu           = 9
  IMPORTING
    goukei_kingaku = g_goukei_kingaku
  EXCEPTIONS
    kosu_error     = 1
    OTHERS         = 2.

* 例外処理
IF sy-subrc <> 0.
* Implement suitable error handling here
ENDIF.

* 合計金額出力
write g_goukei_kingaku.

上記プログラムを実行すると、合計金額(goukei_kingaku)が900と正しく計算され出力されることが確認できます。

プログラムから汎用モジュールを呼び出した結果の出力画面

さいごに

汎用モジュールは複数の機能で共通化した処理として使えるよう、設計者同士で認識の齟齬がないようにする必要があります。
正常系の処理だけではなく、異常系の処理への対処方法も認識合わせることが重要になります。

博士

汎用モジュールの概要と作成方法についての解説は以上じゃ!

新着の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経験者)を募集してますので、お問い合わせよりお願いします!

この記事のポイント