|
|
|||||||||
| 前のクラス 次のクラス | フレームあり フレームなし | |||||||||
| 概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド | |||||||||
java.lang.Objectorg.opengion.fukurou.process.AbstractProcess
org.opengion.fukurou.process.Process_BulkQuery
public class Process_BulkQuery
Process_BulkQueryは、データベースから読み取った内容を、一括処理するために、 ParamProcess のサブクラス(Process_DBParam)にセットしたり、加工したりする FirstProcess と、ChainProcess のインターフェースを両方持った、実装クラスです。 このクラスは、上流から、下流への処理は、1度しか実行されません。 FirstProcess の検索結果は、Set オブジェクトとして、Process_DBParam に渡します。 ChainProcess は、その結果を取り出し、自分自身の処理結果と合せて加工します。 FirstProcess では、-action は、query のみです。 query は、指定のSQL文を実行し、結果のSetをParamProcessに設定します。 ChainProcess では、-action は、query、bulkSet、minus、intersect が指定できます。 query は、上記と同じです。 minus は、先のSetから、SQL文の実行結果を引き算し、結果Setを再設定します。 intersect は、先のSetから、SQL文の実行結果と重複する結果Setを再設定します。 bulkSet は、先のSetを取り出し、SQL文に加味して処理します。 流れ的には、query で検索し、minusまたはintersect でSetオブジェクトを加工し、bulkSet で 利用します。例えば、ORACLEから、ユニークキーのSetを作成し、SQLServerのユニークキーを minusした結果を、ORACLEからDELETEすれば、不要なデータを削除するなどの処理が実行可能になります。 また、単純に、query だけを、チェインすれば、単発のUPDATE文を実行することが可能です。 データベース接続先等は、ParamProcess のサブクラス(Process_DBParam)に 設定された接続(Connection)を使用します。 DBID は、Process_DBParam の -configFile で指定する DBConfig.xml ファイルを使用します。 引数文字列中にスペースを含む場合は、ダブルコーテーション("") で括って下さい。 引数文字列の 『=』の前後には、スペースは挟めません。必ず、-key=value の様に 繋げてください。 SQL文には、{@DATE.YMDH}等のシステム変数が使用できます。
Process_BulkQuery -action=query -dbid=DBGE -sql="select KEY from TABLE_X"
-action=処理方法(必須) : 実行する処理方法を指定します
-action=query 単なるSQL文を実行します。
-action=bulkSet 実行したSQL文の結果を、Set オブジェクトに設定します。
-action=minus Set オブジェクトと、ここでの実行結果の差分をとります。
-action=intersect Set オブジェクトと、ここでの実行結果の積分をとります。
[ -dbid=DB接続ID ] : -dbid=DBGE (例: Process_DBParam の -configFile で指定する DBConfig.xml ファイルで規定)
[ -sql=検索SQL文 ] : -sql="select * from GEA08"
[ -sqlFile=検索SQLファイル ] : -sqlFile=select.sql
-sql= を指定しない場合は、ファイルで必ず指定してください。
[ -sql_XXXX=固定値 ] : -sql_SYSTEM_ID=GE
SQL文中の{@XXXX}文字列を指定の固定値で置き換えます。
WHERE SYSTEM_ID='{@SYSTEM_ID}' ⇒ WHERE SYSTEM_ID='GE'
[ -bulkKey=XXXX ] : -bulkKey=XXXX
SQL文中の{@XXXX}文字列をProcess_BulkQuery等で取得した値で置き換えます。
WHERE SYSTEM_ID IN ( {@XXXX} ) ⇒ WHERE SYSTEM_ID IN ( 'AA','BB','CC' )
[ -bulkType=NUM|STR ] : -bulType=STR
Bulkの値を文字列に変換する場合に、数字型か、文字型を指定します。
数字型では、AA,BB,CC とし、文字型では、'AA','BB','CC' に変換します。(初期値:STR)
[ -fetchSize=100 ] :フェッチする行数(初期値:100)
[ -display=false|true ] :結果を標準出力に表示する(true)かしない(false)か(初期値 false:表示しない)
[ -debug=false|true ] :デバッグ情報を標準出力に表示する(true)かしない(false)か(初期値 false:表示しない) | 5.3.4.0 (2011/04/01) 新規追加 |
| フィールドの概要 |
|---|
| クラス org.opengion.fukurou.process.AbstractProcess から継承されたフィールド |
|---|
CR, TAB |
| コンストラクタの概要 | |
|---|---|
Process_BulkQuery()
デフォルトコンストラクター。 |
|
| メソッドの概要 | |
|---|---|
LineModel |
action(LineModel data)
引数の LineModel を処理するメソッドです。 |
void |
end(boolean isOK)
プロセスの終了を行います。 |
void |
init(ParamProcess paramProcess)
プロセスの初期化を行います。 |
static void |
main(java.lang.String[] args)
このクラスは、main メソッドから実行できません。 |
LineModel |
makeLineModel(int rowNo)
最初に、 行データである LineModel を作成します FirstProcess は、次々と処理をチェインしていく最初の行データを 作成して、後続の ChainProcess クラスに処理データを渡します。 |
boolean |
next()
このデータの処理において、次の処理が出来るかどうかを問い合わせます。 |
java.lang.String |
report()
プロセスの処理結果のレポート表現を返します。 |
java.lang.String |
usage()
このクラスの使用方法を返します。 |
| クラス org.opengion.fukurou.process.AbstractProcess から継承されたメソッド |
|---|
getArgument, logging, println, putArgument, putArgument, setLoggerProcess, toString |
| クラス java.lang.Object から継承されたメソッド |
|---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
| インタフェース org.opengion.fukurou.process.HybsProcess から継承されたメソッド |
|---|
logging, println, putArgument, putArgument, setLoggerProcess |
| コンストラクタの詳細 |
|---|
public Process_BulkQuery()
| メソッドの詳細 |
|---|
public void init(ParamProcess paramProcess)
HybsProcess 内の initparamProcess - ParamProcesspublic void end(boolean isOK)
HybsProcess 内の endisOK - トータルで、OKだったかどうか(true:成功/false:失敗)public boolean next()
FirstProcess 内の nextpublic LineModel action(LineModel data)
ChainProcess 内の actiondata - LineModel オリジナルのLineModel
public LineModel makeLineModel(int rowNo)
FirstProcess 内の makeLineModelrowNo - int 処理中の行番号
public java.lang.String report()
HybsProcess 内の reportpublic java.lang.String usage()
HybsProcess 内の usagepublic static void main(java.lang.String[] args)
args - String[]
|
openGion 5.3.9.0 | ||||||||
| 前のクラス 次のクラス | フレームあり フレームなし | ||||||||
| 概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド | ||||||||