クラス Process_DBWriter

  • すべての実装されたインタフェース:
    ChainProcess, HybsProcess

    public class Process_DBWriter
    extends AbstractProcess
    implements ChainProcess
    Process_DBWriter は、上流から受け取ったデータをデータベースに書き込む CainProcess インターフェースの実装クラスです。 上流(プロセスチェインのデータは上流から下流へと渡されます。)から受け取った LineModel を元に、データベースへの書き込みを行います。 データベース接続先等は、ParamProcess のサブクラス(Process_DBParam)に 設定された接続(Connection)を使用します。 引数文字列中にスペースを含む場合は、ダブルコーテーション("") で括って下さい。 引数文字列の 『=』の前後には、スペースは挟めません。必ず、-key=value の様に 繋げてください。 SQL文には、{@DATE.YMDH}等のシステム変数が使用できます。
    形式サンプル:
    Process_DBWriter -dbid=DBGE -table=GE41 [ -dbid=DB接続ID ] : -dbid=DBGE (例: Process_DBParam の -configFile で指定する DBConfig.xml ファイルで規定) [ -table=登録テーブルID ] : SQL文を指定する場合は不要。INSERT する場合のテーブルID [ -sql=検索SQL文 ] : -sql="UPDATE GE41 SET NAME_JA = [NAME_JA],LABEL_NAME = [LABEL_NAME] WHERE SYSTEM_ID = [SYSTEM_ID] AND CLM = [CLM]" [ -sqlFile=登録SQLファイル ] : -sqlFile=update.sql : -sql や -sqlFile が指定されない場合は、-table で指定のテーブルに全カラム insert です。 [ -sql_XXXX=固定値 ] : -sql_SYSTEM_ID=GE SQL文中の{@XXXX}文字列を指定の固定値で置き換えます。 WHERE SYSTEM_ID='{@SYSTEM_ID}' ⇒ WHERE SYSTEM_ID='GE' [ -const_XXXX=固定値 ] : -const_FGJ=1 LineModel のキー(const_ に続く文字列)の値に、固定値を設定します。 キーが異なれば、複数のカラム名を指定できます。 [ -omitClms=AAA,BBB,… ] : -omitClms=UNIQ,FGJ,DYSET -table 属性でINSERT文を自動作成する場合、取り除くカラム名を CSV形式で複数指定できます。 [ -initSql=開始時SQL文 ] : -initSql="DELETE FROM GE41 WHERE FGJ = '9'" [ -initSqlFile=開始時SQLファイル] : -initSqlFile=update.sql [ -endSql=終了時SQL文 ] : -endSql="UPDATE GE41 SET FGJ = '1'" [ -endSqlFile=終了時SQLファイル ] : -endSqlFile=update.sql [ -commitCnt=commit処理指定 ] : 指定数毎にコミットを発行します。0 の場合は、終了までコミットしません。 [ -display=[false/true] ] : 結果を標準出力に表示する(true)かしない(false)か(初期値:false[表示しない]) [ -debug=[false/true] ] :デバッグ情報を標準出力に表示する(true)かしない(false)か(初期値:false[表示しない])
    バージョン
    4.0
    作成者
    Kazuhiko Hasegawa
    導入されたバージョン:
    JDK5.0,
    • コンストラクタの詳細

      • Process_DBWriter

        public Process_DBWriter()
        デフォルトコンストラクター。 このクラスは、動的作成されます。デフォルトコンストラクターで、 super クラスに対して、必要な初期化を行っておきます。
    • メソッドの詳細

      • init

        public void init​(ParamProcess paramProcess)
        プロセスの初期化を行います。初めに一度だけ、呼び出されます。 初期処理(ファイルオープン、DBオープン等)に使用します。
        定義:
        init インタフェース内 HybsProcess
        パラメータ:
        paramProcess - データベースの接続先情報などを持っているオブジェクト
        変更履歴:
        4.0.0.0 (2007/09/21) omitClms 属性を追加, 5.1.1.0 (2009/11/11) setObject に ParameterMetaData の getParameterType を渡す。(PostgreSQL対応), 5.3.8.0 (2011/08/01) useParamMetaData を ConnectionFactory経由で取得。(PostgreSQL対応), 5.7.2.2 (2014/01/24) initSql,initSqlFile,endSql,endSqlFile 追加
      • end

        public void end​(boolean isOK)
        プロセスの終了を行います。最後に一度だけ、呼び出されます。 終了処理(ファイルクローズ、DBクローズ等)に使用します。
        定義:
        end インタフェース内 HybsProcess
        パラメータ:
        isOK - トータルで、OKだったかどうか[true:成功/false:失敗]
        変更履歴:
        4.0.0.0 (2007/11/27) commit,rollback,remove 処理を追加, 5.1.1.0 (2009/11/11) pMeta のクリア, 5.7.2.2 (2014/01/24) endSql 処理の追加, 6.9.4.1 (2018/04/09) DB_BATCH_SIZE 指定を行います。
      • action

        public LineModel action​(LineModel data)
        引数の LineModel を処理するメソッドです。 変換処理後の LineModel を返します。 後続処理を行わない場合(データのフィルタリングを行う場合)は、 null データを返します。つまり、null データは、後続処理を行わない フラグの代わりにも使用しています。 なお、変換処理後の LineModel と、オリジナルの LineModel が、 同一か、コピー(クローン)かは、各処理メソッド内で決めています。 ドキュメントに明記されていない場合は、副作用が問題になる場合は、 各処理ごとに自分でコピー(クローン)して下さい。
        定義:
        action インタフェース内 ChainProcess
        パラメータ:
        data - オリジナルのLineModel
        戻り値:
        処理変換後のLineModel
        変更履歴:
        5.1.1.0 (2009/11/11) setObject に ParameterMetaData の getParameterType を渡す。(PostgreSQL対応), 5.3.8.0 (2011/08/01) useParamMetaData setNull 対応(PostgreSQL対応), 5.7.2.2 (2014/01/24) SQL実行エラーを少し詳細に出力します。, 6.9.4.1 (2018/04/09) DB_BATCH_SIZE 指定を行います。
      • report

        public String report()
        プロセスの処理結果のレポート表現を返します。 処理プログラム名、入力件数、出力件数などの情報です。 この文字列をそのまま、標準出力に出すことで、結果レポートと出来るような 形式で出してください。
        定義:
        report インタフェース内 HybsProcess
        戻り値:
        処理結果のレポート
      • usage

        public String usage()
        このクラスの使用方法を返します。
        定義:
        usage インタフェース内 HybsProcess
        戻り値:
        このクラスの使用方法
        このメソッドは、nullを返しません
      • main

        public static void main​(String[] args)
        このクラスは、main メソッドから実行できません。
        パラメータ:
        args - コマンド引数配列