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[表示しない])BUFFER_LARGE, BUFFER_MIDDLE, CR, TAB| コンストラクタと説明 |
|---|
Process_DBWriter()
デフォルトコンストラクター。
|
| 修飾子とタイプ | メソッドと説明 |
|---|---|
LineModel |
action(LineModel data)
引数の LineModel を処理するメソッドです。
|
void |
end(boolean isOK)
プロセスの終了を行います。
|
void |
init(ParamProcess paramProcess)
プロセスの初期化を行います。
|
static void |
main(java.lang.String[] args)
このクラスは、main メソッドから実行できません。
|
java.lang.String |
report()
プロセスの処理結果のレポート表現を返します。
|
java.lang.String |
usage()
このクラスの使用方法を返します。
|
getArgument, logging, println, putArgument, putArgument, setLoggerProcess, throwException, throwException, toStringclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitlogging, println, putArgument, putArgument, setLoggerProcesspublic Process_DBWriter()
public void init(ParamProcess paramProcess)
init インタフェース内 HybsProcessparamProcess - データベースの接続先情報などを持っているオブジェクト| 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 追加 |
public void end(boolean isOK)
end インタフェース内 HybsProcessisOK - トータルで、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 処理の追加 |
public LineModel action(LineModel data)
action インタフェース内 ChainProcessdata - オリジナルの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実行エラーを少し詳細に出力します。 |
public java.lang.String report()
report インタフェース内 HybsProcesspublic java.lang.String usage()
usage インタフェース内 HybsProcesspublic static void main(java.lang.String[] args)
args - コマンド引数配列Webアプリケーションフレームワーク openGionCopyright (c) 2009 The openGion Project.