クラス DirectXMLSaveTag
java.lang.Object
jakarta.servlet.jsp.tagext.TagSupport
jakarta.servlet.jsp.tagext.BodyTagSupport
org.opengion.hayabusa.taglib.CommonTagSupport
org.opengion.hayabusa.taglib.DirectXMLSaveTag
- すべての実装されたインタフェース:
BodyTag
,IterationTag
,JspTag
,Tag
,TryCatchFinally
,Serializable
指定の拡張XDK形式ファイルを直接データベースに登録するデータ入力タグです。
このクラスは、オラクル XDKの oracle.xml.sql.dml.OracleXMLSave クラスと
ほぼ同様の目的で使用できる org.opengion.fukurou.xml.XMLFileLoader のラッパークラスです。
拡張XDK形式のXMLファイルを読み込み、データベースに INSERT します。
拡張XDK形式の元となる オラクル XDK(Oracle XML Developer's Kit)については、以下の
リンクを参照願います。
XDK(Oracle XML Developer's Kit)
このタグでは、keys,vals を登録することにより、XMLファイルに存在しないカラムを
追加したり、XMLファイルの情報を書き換えることが可能になります。
例えば、登録日や、登録者、または、テンプレートより各システムID毎に
登録するなどです。
拡張XDK形式とは、ROW 以外に、SQL処理用タグ(EXEC_SQL)を持つ XML ファイルです。
また、登録するテーブル(table)を ROWSETタグの属性情報として付与することができます。
(大文字小文字に注意)
これは、オラクルXDKで処理する場合、無視されますので、同様に扱うことが出来ます。
この、EXEC_SQL は、それそれの XMLデータをデータベースに登録する際に、
SQL処理を自動的に流す為の、SQL文を記載します。
この処理は、イベント毎に実行される為、その配置順は重要です。
このタグは、複数記述することも出来ますが、BODY部には、1つのSQL文のみ記述します。
6.0.0.0 (2014/04/11)
指定のファイルがフォルダの場合は、以下のファイルすべて(拡張子はxml)を対象に読込-登録します。
また、拡張子が、zip の場合は、zip内部の xml ファイルを読込-登録します。
※ このタグは、Transaction タグの対象です。
<ROWSET tableName="XX" >
<EXEC_SQL> 最初に記載して、初期処理(データクリア等)を実行させる。
delete from GEXX where YYYYY
</EXEC_SQL>
<MERGE_SQL> このSQL文で UPDATEして、結果が0件ならINSERTを行います。
update GEXX set AA=[AA] , BB=[BB] where CC=[CC]
</MERGE_SQL>
<ROW num="1">
<カラム1>値1</カラム1>
・・・
<カラムn>値n</カラムn>
</ROW>
・・・
<ROW num="n">
・・・
</ROW>
<EXEC_SQL> 最後に記載して、項目の設定(整合性登録)を行う。
update GEXX set AA='XX' , BB='XX' where YYYYY
</EXEC_SQL>
<ROWSET>
- 関連項目:
- 変更履歴:
- 4.0.0.0 (2007/03/08) 新規追加, 6.0.0.0 (2014/04/11) 単体ファイル以外(フォルダ、ZIPファイル)への対応
- 機能分類
- ファイル入力
- 形式サンプル:
- ●形式:<og:directXMLSave fileURL="[・・・]" ・・・ /> ●body:なし ●Tag定義: <og:directXMLSave dbid 【TAG】(通常は使いません)検索時のDB接続IDを指定します(初期値:DEFAULT) fileURL 【TAG】読み取り元ディレクトリ名を指定します (初期値:FILE_URL[=filetemp/]) filename 【TAG】ファイルを作成するときのファイル名をセットします (初期値:null) displayMsg 【TAG】query の結果を画面上に表示するメッセージIDを指定します(初期値:MSG0003[ファイルの登録が完了しました。]) keys 【TAG】XMLファイルを読み取った後で指定するキーをCSV形式で複数指定します vals 【TAG】XMLファイルを読み取った後で指定する値をCSV形式で複数指定します useTimeStamp 【TAG】XMLファイルの読み取りで、タイムスタンプ管理を行うかどうか[true:行う/false:行わない]指定します(初期値:false) useTimeView 【TAG】処理時間を表示する TimeView を表示するかどうかを指定します (初期値:VIEW_USE_TIMEBAR[=])。 caseKey 【TAG】このタグ自体を利用するかどうかの条件キーを指定します(初期値:null) caseVal 【TAG】このタグ自体を利用するかどうかの条件値を指定します(初期値:null) caseNN 【TAG】指定の値が、null/ゼロ文字列 でない場合(Not Null=NN)は、このタグは使用されます(初期値:判定しない) caseNull 【TAG】指定の値が、null/ゼロ文字列 の場合は、このタグは使用されます(初期値:判定しない) caseIf 【TAG】指定の値が、true/TRUE文字列の場合は、このタグは使用されます(初期値:判定しない) debug 【TAG】デバッグ情報を出力するかどうか[true/false]を指定します(初期値:false) /> ●使用例 <og:directXMLSave dbid = "ORCL" 接続データベースID(初期値:DEFAULT) fileURL = "{@USER.ID}" 読み取り元ディレクトリ名 filename = "{@filename}" 読み取り元ファイル名 displayMsg = "MSG0003" 登録完了後のメッセージ />
- 導入されたバージョン:
- JDK5.0,
-
フィールドの概要
クラスから継承されたフィールド org.opengion.hayabusa.taglib.CommonTagSupport
BR, BUFFER_MIDDLE, CR
クラスから継承されたフィールド jakarta.servlet.jsp.tagext.BodyTagSupport
bodyContent
クラスから継承されたフィールド jakarta.servlet.jsp.tagext.TagSupport
id, pageContext
インタフェースから継承されたフィールド jakarta.servlet.jsp.tagext.BodyTag
EVAL_BODY_BUFFERED, EVAL_BODY_TAG
インタフェースから継承されたフィールド jakarta.servlet.jsp.tagext.IterationTag
EVAL_BODY_AGAIN
インタフェースから継承されたフィールド jakarta.servlet.jsp.tagext.Tag
EVAL_BODY_INCLUDE, EVAL_PAGE, SKIP_BODY, SKIP_PAGE
-
コンストラクタの概要
コンストラクタ -
メソッドの概要
修飾子とタイプメソッド説明int
doEndTag()
Taglibの終了タグが見つかったときに処理する doEndTag() を オーバーライドします。protected void
release2()
タグリブオブジェクトをリリースします。void
【TAG】(通常は使いません)検索時のDB接続IDを指定します(初期値:DEFAULT)。void
setDisplayMsg
(String id) 【TAG】query の結果を画面上に表示するメッセージIDを指定します(初期値:MSG0003[ファイルの登録が完了しました])。void
setFilename
(String fname) 【TAG】ファイルを作成するときのファイル名をセットします(初期値:null)。void
setFileURL
(String url) 【TAG】読み取り元ディレクトリ名を指定します (初期値:FILE_URL[=])。void
【TAG】XMLファイルを読み取った後で指定するキーをCSV形式で複数指定します。void
setUseTimeStamp
(String flag) 【TAG】タイムスタンプ管理を行うかどうか[true:行う/false:行わない]を指定します(初期値:false)。void
setUseTimeView
(String flag) 【TAG】処理時間を表示する TimeView を表示するかどうか[true:する/false:しない]を指定します (初期値:VIEW_USE_TIMEBAR[=])。void
【TAG】XMLファイルを読み取った後で指定する値をCSV形式で複数指定します。toString()
このオブジェクトの文字列表現を返します。クラスから継承されたメソッド org.opengion.hayabusa.taglib.CommonTagSupport
add, add, addEventColumn, addEventColumn, check, commitTableObject, debugPrint, debugPrint, doAfterBody, doCatch, doFinally, doStartTag, get, getApplicationInfo, getAttributes, getBodyRawString, getBodyString, getContextAttribute, getContextPath, getCookie, getCSVParameter, getCSVParameter, getDateFormat, getDBColumn, getDBFunctionName, getDocumentLink, getGUIInfo, getGUIInfoAttri, getHostName, getLabel, getLabelInterface, getLanguage, getLongLabel, getMsg, getMsglbl, getObject, getParameterNames, getParameterRows, getRequest, getRequestAttribute, getRequestCacheData, getRequestMethod, getRequestParameter, getRequestParameterValues, getRequestValue, getRequestValue, getRequestValues, getReservedParameter, getReservedValue, getResource, getSanitizedBodyString, getScope, getSessionAttribute, getTagName, getTransaction, getUser, getUserEditInfo, getUserInfo, isAjaxSubmitRequest, isDebug, isNoTransitionRequest, isNull, jspPrint, makeUrl, removeContextAttribute, removeObject, removeRequestAttribute, removeSessionAttribute, set, setAjaxSubmitRequest, setCaseIf, setCaseKey, setCaseNN, setCaseNull, setCaseVal, setContextAttribute, setCookie, setDebug, setLanguage, setLbl, setNoTransitionRequest, setObject, setObject, setParameterNames, setParameterRows, setRequestAttribute, setRequestCacheData, setScope, setSessionAttribute, setUserInfo, startQueryTransaction, sys, sysBool, sysInt, useMainTrans, useQuotCheck, useStrict, useTag, useXssCheck
クラスから継承されたメソッド jakarta.servlet.jsp.tagext.BodyTagSupport
doInitBody, getBodyContent, getPreviousOut, release, setBodyContent
クラスから継承されたメソッド jakarta.servlet.jsp.tagext.TagSupport
findAncestorWithClass, getId, getParent, getValue, getValues, removeValue, setId, setPageContext, setParent, setValue
クラスから継承されたメソッド java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
インタフェースから継承されたメソッド jakarta.servlet.jsp.tagext.Tag
getParent, setPageContext, setParent
-
コンストラクタの詳細
-
DirectXMLSaveTag
public DirectXMLSaveTag()デフォルトコンストラクター- 変更履歴:
- 6.4.2.0 (2016/01/29) PMD refactoring. Each class should declare at least one constructor.
-
-
メソッドの詳細
-
doEndTag
Taglibの終了タグが見つかったときに処理する doEndTag() を オーバーライドします。- 定義:
doEndTag
インタフェース内Tag
- オーバーライド:
doEndTag
クラス内CommonTagSupport
- 戻り値:
- 後続処理の指示
- 変更履歴:
- 4.0.0.0 (2007/10/18) メッセージリソース統合( getResource().getMessage ⇒ getResource().getLabel ), 4.0.0.1 (2007/12/03) try ~ catch ~ finally をきちんと行う。, 5.1.9.0 (2010/08/01) Transaction 対応, 5.3.7.0 (2011/07/01) TransactionReal の引数変更, 5.5.2.6 (2012/05/25) findbugs対応。例外経路で null 値を利用することが保証されています。, 5.6.6.1 (2013/07/12) caseKey、caseVal 属性対応, 5.6.7.0 (2013/07/27) DDL(データ定義言語:Data Definition Language)の処理件数追加, 6.0.2.0 (2014/09/19) useTimeStamp 属性追加。タイムスタンプ管理を行うかどうか, 6.3.5.1 (2015/08/16) doStartTag() 削除に伴う、dyStart の移動。, 6.3.6.1 (2015/08/28) Transaction でAutoCloseableを使用したtry-with-resources構築に対応。
-
release2
タグリブオブジェクトをリリースします。 キャッシュされて再利用されるので、フィールドの初期設定を行います。- オーバーライド:
release2
クラス内CommonTagSupport
- 変更履歴:
- 4.0.0.0 (2007/10/10) dbid の初期値を、"DEFAULT" から null に変更, 6.0.0.0 (2014/04/11) filename の初期値を、システムプロパティーのFILE_FILENAME から null に変更, 6.0.0.0 (2014/04/11) displayMsg の初期値を、MSG0040 から MSG0003 に変更, 6.0.2.0 (2014/09/19) useTimeStamp 属性追加。タイムスタンプ管理を行うかどうか
-
setDbid
【TAG】(通常は使いません)検索時のDB接続IDを指定します(初期値:DEFAULT)。- パラメータ:
id
- データベース接続ID- 説明:
- 検索時のDB接続IDを指定します。初期値は、DEFAULT です。
-
setFileURL
【TAG】読み取り元ディレクトリ名を指定します (初期値:FILE_URL[=])。- パラメータ:
url
- ファイルURL- 関連項目:
- 変更履歴:
- 4.0.0.0 (2007/11/20) 指定されたディレクトリ名の最後が"\"or"/"で終わっていない場合に、"/"を付加する。, 6.4.2.1 (2016/02/05) URLの最後に、"/" を追加する処理を廃止。
- 説明:
- この属性で指定されるディレクトリより、ファイルを読み取ります。 指定方法は、通常の fileURL 属性と同様に、先頭が、'/' (UNIX) または、2文字目が、 ":" (Windows)の場合は、指定のURLそのままのディレクトリに、そうでない場合は、 fileURL = "{@USER.ID}" と指定すると、FILE_URL 属性で指定のフォルダの下に、 さらに、各個人ID別のフォルダの下より、読み取ります。 (初期値:システム定数のFILE_URL[=])。
-
setFilename
【TAG】ファイルを作成するときのファイル名をセットします(初期値:null)。- パラメータ:
fname
- ファイル名- 変更履歴:
- 6.0.0.0 (2014/04/11) filename の初期値を、システムプロパティーのFILE_FILENAME から null に変更
- 説明:
- ファイルを作成するときのファイル名をセットします。 (初期値:null)。
-
setDisplayMsg
【TAG】query の結果を画面上に表示するメッセージIDを指定します(初期値:MSG0003[ファイルの登録が完了しました])。- パラメータ:
id
- 処理結果表示メッセージID- 説明:
- ここでは、検索結果の件数や登録された件数をまず出力し、 その次に、ここで指定したメッセージをリソースから取得して 表示します。 表示させたくない場合は、displayMsg = "" をセットしてください。 初期値は、検索件数を表示します。 ※ この属性には、リクエスト変数({@XXXX})は使用できません。
-
setKeys
【TAG】XMLファイルを読み取った後で指定するキーをCSV形式で複数指定します。- パラメータ:
key
- リンク先に渡すキー- 関連項目:
- 説明:
- XMLファイルを読み取った後で、データを変更できます。
変更するカラム名(キー)をCSV形式で指定します。
XMLファイルにキーが存在していた場合は、vals で指定の値に書き換えます。
キーが存在していない場合は、ここで指定するキーと値が、データとして 追加されます。例えば、登録日や、登録者、または、テンプレートより各システムID毎に 登録するなどの使い方を想定しています。 分解方法は、CSV変数を先に分解してから、getRequestParameter で値を取得します。 こうしないとデータ自身にカンマを持っている場合に分解をミスる為です。
-
setVals
【TAG】XMLファイルを読み取った後で指定する値をCSV形式で複数指定します。- パラメータ:
val
- keys属性に対応する値- 関連項目:
- 説明:
- XMLファイルを読み取った後で、データを変更できます。
変更する値をCSV形式で指定します。
XMLファイルにキーが存在していた場合は、vals で指定の値に書き換えます。
キーが存在していない場合は、ここで指定するキーと値が、データとして 追加されます。例えば、登録日や、登録者、または、テンプレートより各システムID毎に 登録するなどの使い方を想定しています。 分解方法は、CSV変数を先に分解してから、getRequestParameter で値を取得します。 こうしないとデータ自身にカンマを持っている場合に分解をミスる為です。
-
setUseTimeStamp
【TAG】タイムスタンプ管理を行うかどうか[true:行う/false:行わない]を指定します(初期値:false)。- パラメータ:
flag
- タイムスタンプ管理 [true:行う/false:行わない]- 変更履歴:
- 6.0.2.0 (2014/09/19) 新規追加
- 説明:
- useTimeStamp=true の場合、登録の実行有無の判断は、ファイルの更新時刻より判断します。 これは、読み取りファイルの更新時刻が、0でない場合、読み取りを行います。 読み取りが完了した場合は、更新時刻を 0 に設定します。 つまり、一度しか読み込まないように制御できます。 useTimeStamp=false の場合は、無条件に読み込みます。
-
setUseTimeView
【TAG】処理時間を表示する TimeView を表示するかどうか[true:する/false:しない]を指定します (初期値:VIEW_USE_TIMEBAR[=])。- パラメータ:
flag
- 処理時間を表示 [true:する/false:しない]- 変更履歴:
- 6.3.6.0 (2015/08/16) useTimeView の初期値を、VIEW_USE_TIMEBAR にする。
- 説明:
- true に設定すると、処理時間を表示するバーイメージが表示されます。 これは、DB検索、APサーバー処理、画面表示の各処理時間をバーイメージで 表示させる機能です。処理時間の目安になります。 (初期値:VIEW_USE_TIMEBAR[=])。
-
toString
このオブジェクトの文字列表現を返します。 基本的にデバッグ目的に使用します。- オーバーライド:
toString
クラス内CommonTagSupport
- 戻り値:
- このクラスの文字列表現
- このメソッドは、nullを返しません
-