2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

IBM Cloud PowerVSのIBM i にデータベースファイルを転送したい

Last updated at Posted at 2022-12-09

オンプレだと悩む暇なくできてしまうのですがクラウドだと色々お作法が必要でした、というお話です。

掲題、オンプレだとSAVFをローカルに用意する→FTP転送する。以上。なのですが、、
今回は(も)パブリックN/WからPowerVSに接続する想定のため、SSH接続前提→SFTP転送になるのですが、SFTPではSAVFを転送できない。(SFTPはIFSかPFのみOK,PCローカルにPFはつくれない…)、となります。

ない頭を絞って考えたもっともラクチンな方法が以下です。
手順1.ターゲットのPowerVS上にDb2テーブルを作成する (CRTPTF OR SQL DDL)
今回はSEUで別サーバーのDDSをコピーしました。DDL生成して流した方がスマートだったなと後で気づきました‥
手順2.別サーバーのDb2からアップロード用のxlsxファイルを用意する。*この操作もACSのデータ転送機能を利用しました。アップロード時に必要な定義ファイル(.fdfx)を生成するためです。
手順3.SSH経由でACSデータ転送を起動、xlsxファイルをIBM i にアップロードします。
image.png

以下の手順は、前提としてACS導入済み、Windows(ほか)にsshクライアントが導入済み、sshでIBM iに接続済み、の前提です。この辺の手順は以下に記載しています。
■IBM CloudのIBM i にACSでssh接続する手順
https://qiita.com/gomAnomalocaris/items/9eb2ced60c9830704b65

手順1.Db2 for i テーブルを作成する

今回はレガシーな5250からSEUでテーブル定義を記述し、CRTPFコマンドでテーブルを作成しました。実際は別システムの5250開いてコピペしました‥技術者の風上にも置けません。
image.png

・・・ですが、今どきの技術者は元システムでテーブルをACSその他SQLインターフェースから開いて元テーブルのDDLを生成するのがいいと思います。
下記例ではACSからスキーマを実行し、該当のテーブルを右クリックしてSQLの生成 を選択し、
image.png

内容を確認します。通常変更するパラメーター等はありません。利用目的によってはオプション欄でANSI形式でDDLを生成する等設定ができます。(デフォルトはDb2形式で生成)。また、今回は生成したDDLをウィンドウに表示しますが、ファイル保管も可能です。ウィンドウ右下の生成ボタンを押します。
image.png

生成中のメッセージが一瞬出て…
image.png

DDLが生成されました。これをターゲットのPowerVSのSQLスクリプト実行画面に張り付けて実行すればテーブルを作成できます。
image.png

手順2.ACSでXLSXファイルをダウンロード&アップロードする

まず今回オンプレの別システムから得意先マスターのデータをXLSXでダウンロードします。
ACSのエミュレーター画面等から IBM i からのデータ転送 を開いて、参考に設定画面を添付します。
image.png
image.png

上記を設定し、転送の開始 ボタンを押すとXLSXファイルがPCローカルに生成されます。
ここで生成したXLSXとクライアントファイル記述 FDFXを使用してPowerVSにデータ転送します。

IBM i へのデータ転送 を開いて以下のようなパラメーターを入力します。
注意点としてSSH経由でデータ転送するので、宛先ホスト名がPowerVS IBM iではなくlocalhostになる点です。もし接続先システムに未登録の場合は、ACSシステム構成画面からlocalhostを追加してください。
image.png

用意が完了したらACSでPowerVSにアップロードします。
image.png
ファイルの詳細 画面でクライアント・ファイル記述を使用するにチェックし、ダウンロード時作成したfdfxファイル名を指定します。今回のケースでは メンバー置換のみ、の設定でアップロードします。
image.png

転送の開始 ボタンを押すとアップロードが実行されます。
今回途中で転送が止まってしまいました…あれれ?
image.png
とおもったらテーブル初期値が最大13,000レコードでした。この辺は変わってないですね~。レコード件数の拡張をOK返すと、、
image.png
無事アップロードが完了しました。

お疲れ様でした~♪
image.png

■2923/10/19追記■
・・・ところが実はsftpでもSAVFが転送可能である、との情報を今更見つけました…
こちらです。筆者様に感謝。
WinSCPを使って”IBM i”のライブラリーへ「*SAVF」を転送
https://ushiday.hatenablog.jp/entry/20091111/1257909397

ポイントは
・PCローカルの転送元SAVFの拡張子を .FILE にする(例 LIB_SAVF.FILE)
以上です。
あとは、sftpセッション中で
put C:\LIB_SAVF.FILE
等とすればOKでした。

2
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?