バイナリファイルをデータベースにテキストデータとして書き込みたい

キーワード:Base64,エンコード,DB,データベース,書き込み
シナリオ一覧に戻る

概要

バイナリファイルをデータベースにテキストデータとして書き込みたい場合、ファイルシステム読み取り処理を使用します。
ファイルシステム読み取り処理によってバイナリファイルを読み取り、テキストデータとしてデータベースに書き込みます。

サンプルプロジェクトの説明

指定したディレクトリのファイルをバイナリ形式で読み取り、Base64形式に変換後、データベースの文字列型カラムに書き込みます。

処理の流れ

サンプルプロジェクトの処理の流れは以下の通りです。
  1. ファイルシステム読み取り処理」でバイナリデータを取得します。
  2. マッピング処理」で、取得したデータの「filetype」が「file」のデータを抽出します。
  3. テーブル書き込み処理」でBase64形式に変換されたバイナリデータを書き込みます。
実行結果のイメージは以下の通りです。

ポイントとなる機能

名前 説明 ツールパレット上の場所
ファイルシステム読み取り処理 ディレクトリにあるファイルやディレクトリのデータ構造を読み取ります。 「ファイル」-「ファイルシステム」-「ファイルシステム読み取り」

処理のポイント

Base64形式は、バイナリデータを英数字のテキストデータに変換する方式となります。
文字列型としてバイナリデータを扱いたい場合、Base64形式に変換したテキストデータを使用します。 取得したバイナリデータは、出力先で文字列型として扱われる場合にBase64形式に変換されます。

サンプルプロジェクトの使用方法

上記処理を実装したサンプルプロジェクトを用意しています。サンプルプロジェクトを使用する場合の手順は、以下の通りです。

サンプルプロジェクトファイル名 rl_reference_066.zip
  1. サンプルプロジェクトの展開
    サンプルプロジェクトファイル「rl_reference_066.zip」を展開します。

  2. プロジェクトのアップロード
    「rl_reference_066.zip」を展開後に作成される「rl_reference_066プロジェクト」ディレクトリがプロジェクトファイルとなります。
    DataSpider Studioを起動し、マイプロジェクトの画面から[ファイル]-[ローカルからアップロード]で展開したディレクトリ「rl_reference_066プロジェクト」をアップロードしてください。

  3. サンプルデータの準備
    「rl_reference_066.zip」を展開後に作成される「samples」ディレクトリがサンプルデータとなります。
    $DATASPIDER_HOME/server/samplesディレクトリに上書きしてください。

  4. コントロールパネルの[グローバルリソースの設定]から、[新しいグローバルリソースの追加]を選択し、SQL Server(JDBC接続)アダプタのグローバルリソースを作成します。
  5. グローバルリソースの作成方法については、「グローバルリソースのプロパティ」を参照してください。

スクリプトの作成手順

プロセスフローおよびデータフローは、「サンプルプロジェクトの説明」のスクリプト画像を参照して適宜設定してください。
  1. デザイナのツールパレット「ファイル」-「ファイルシステム」-「ファイルシステム読み取り」から、ファイルシステム読み取り処理をスクリプトキャンバスに配置します。

  2. デザイナのツールパレット「変換」-「基本」-「マッピング」から、マッピング処理をスクリプトキャンバスに配置します。

  3. デザイナのツールパレット「データベース」-「SQL Server」-「テーブル書き込み」から、テーブル書き込み処理をスクリプトキャンバスに配置します。

  4. マッピング処理のMapperエディタを開き、取得したデータの「filetype」が「file」のデータを抽出する処理を作成します。

  5. スクリプトを実行し、正常終了すれば成功です。