はじめに
本記事ではSPSS Modeler FlowでMergeノード(レコード結合ノード)を扱う上で、特に入力順序の設定に関する留意事項をまとめています。
Desktop版からCP4DaaS版に環境移行されるかた、CP4DaaS版で度々同一のMergeノード設定を変更されているかたは是非ご一読ください。
背景
今回の記事執筆に至るまでの背景を説明します。
- SPSS Modeler Desktop版で作成されたストリームをSPSS Modeler Flow(※以下、CP4DaaS版と記載)に環境移行するタスクを実施
- 環境移行前後で終端テーブルの出力結果が一致していないことを確認
- 調査の結果、「Desktop版とCP4DaaS版とで、操作画面上のMergeノードの設定内容は同一なのに出力結果が一致しない」事象を確認
- 製品サポートに問い合わせた結果、Mergeノードに関する(奇妙な)挙動が発覚
- 2023年10月現在もバグ未修正の様子
検証パターン
前項「背景」3番の事象詳細について、サンプルデータで説明します。
紹介順は以下です。
- Desktop版(Modeler Client)
- ①販売データ、商品情報の順で結合
- ②商品情報、販売データの順で結合
- CP4DaaS版(Modeler Flow)
- ③販売データ、商品情報の順で結合
- ④商品情報、販売データの順で結合
検証詳細
Desktop版|販売データ、商品情報の順で結合
サンプルデータとして、「販売データ」「商品情報」の2テーブルを記載の順序で部分結合します。
順序入れ替えは簡単で、Mergeノードの設定で入力タブから手動で順序を入れ替えます。
結合結果は以下です。
左から商品名、No.、販売数、商品ID、製造メーカーの順に結合できています。
Desktop版|商品情報、販売データの順で結合
続けて、結合順序を入れ替えて「商品情報」「販売データ」の順で結合結果を見てみます。
結合結果は以下です。
結合順序を入れ替えたことで、左から商品名、商品ID、製造メーカー、No.、販売数の順に結合されています。

CP4DaaS版|販売データ、商品情報の順で結合
Desktop版と同様に結合させます。

出力結果は以下です。
Desktop版と同様に、左から商品名、No.、販売数、商品ID、製造メーカーの順に結合できています。
CP4DaaS版|商品情報、販売データの順で結合
画面上で入力順序を入れ替えて出力します。
ここでは、商品情報の左端にチェックをつけ、右端の「上へ移動」をクリックし、保存します。
出力結果は以下です。
本来なら結合順序を入れ替えたことで、左から商品名、商品ID、製造メーカー、No.、販売数の順に結合されているはずですが、 販売データ、商品情報の順で結合させたとき から結果が変わっていません。
検証まとめ
マージノードの結合入力順序を入れ替える際、
- Desktop版(Modeler Client):設定済みの結合入力順序を更新すると、更新後の順序で結合処理される
- CP4DaaS版(Modeler Flow):設定済みの結合入力順序を更新しても、画面上では順序更新できているように見えるが処理や出力では更新内容が反映されない。
製品サポートに聞いてみた
タイトル通り製品サポートに問い合わせたところ、以下回答が得られました(ニュアンス翻訳です)
- CP4DaaS版では初期設定の入力順序が継続記憶されるため、画面上で入力順序を入れかえても最初に設定された順序で処理される
- 入力順序を正しく入れ替えるには都度Mergeノードを新規作成し、正しい入力順で設定すること
回答にあったように、Mergeノードを新規作成したところ意図した順序で結合ができました。
最後に
(手間ですが)Mergeノードの設定変更時には都度ノードを新規作成のうえ設定するのが良いでしょう。
またMergeノード以外にも同様の事象が起こりうる可能性がありますので、総じてCP4DaaS上で設定変更する際にはノードを新規作成するのがベターです。
お断り
このサイトの掲載内容は私自身の見解であり、必ずしも所属会社の立場、戦略、意見を代表するものではありません。 記事は執筆時点の情報を元に書いているため、必ずしも最新情報であるとはかぎりません。 記事の内容の正確性には責任を負いません。自己責任で実行してください。
参考サイト
- IBM SPSSソフトウェア公式サイト:https://www.ibm.com/jp-ja/spss
- IBM SPSS Modeler(公式サイト、英語):https://www.ibm.com/products/spss-modeler
- SPSS Modeler Flowとは: IBM Cloud Pak for Data > Docs > データの分析とモデルの操作 > SPSS Modeler
- SPSS Modeler Mergeノード:https://www.ibm.com/docs/ja/spss-modeler/saas?topic=nodes-merge-node