/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatKKDchskmstUpd
*	ソースファイル名	：JBSbatKKDchskmstUpd.java
*	作成者				：富士通　
*	作成日				：2012年05月16日
*＜機能概要＞
*　データ抽出項目設定更新部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2012/05/16   富士通		新規作成
*	v1.00.01	2013/03/22   富士通		【IT1-2013-0000627】バッチ異常メッセージ対応
*********************************************************************/
package eo.business.service;

import java.util.HashMap;

import eo.business.common.JBSbatBusinessService;
import eo.business.common.JCCBatCommon;
import eo.business.util.file.JBSbatKKIFM198;
import eo.business.util.table.JBSbatKK_T_DCHSKMST;
import eo.framework.item.JBSbatCommonItem;
import eo.framework.item.JBSbatServiceInterfaceMap;
import eo.framework.item.JBSbatOutputItem;
import eo.framework.item.JBSbatCommonDBInterface;
import eo.framework.log.JBSbatLogUtil;
import eo.framework.db.JBSbatSQLAccess;
import eo.framework.util.JBSbatCheckUtil;

/**
* (クラスの機能概要) <p>
*<BR>
* @author 富士通
*/
public class JBSbatKKDchskmstUpd extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/** テーブル(データ抽出項目設定)*/
	private static final String D_TBL_NAME_KK_T_DCHSKMST = "KK_T_DCHSKMST";

	/** SQL定義キー(KK_INSERT_002)*/
	private static final String KK_T_DCHSKMST_KK_INSERT_002 = "KK_INSERT_002";

	/** SQL定義キー(KK_INSERT_003)*/
	private static final String KK_T_DCHSKMST_KK_INSERT_003 = "KK_INSERT_003";

	/** テーブルアクセスクラス(データ抽出項目設定)*/
	private JBSbatSQLAccess db_KK_T_DCHSKMST = null;
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/

	/** 入力情報(データ抽出項目・適用数)*/
	private String AplyCnt = null;

	/** 入力情報(データ抽出項目・抽出回数)*/
	private String ChshtCnt = null;

	/** システム日付 */
	private String sysDateTime = null;

	/** 入力情報(データ抽出項目設定・データ抽出項目設定番号)*/
	private String DchskmstNo = "";

	/** 入力情報(データ抽出項目設定・世代登録年月日時分秒)*/
	private String GeneAddDtm = "";

	/** 入力情報(データ抽出項目設定・更新年月日時分秒)*/
	private String UpdDtm = "";

	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);

		// DBアクセスクラスを生成します
		db_KK_T_DCHSKMST = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KK_T_DCHSKMST);
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @param inMap　入力電文
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute(JBSbatServiceInterfaceMap inMap) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		super.logPrint.printDebugLog("execute_START");

		// 入力レコードに異常があった場合
		if (inMap.isInputErrorFlg())
		{
			// 業務エラーログ出力
			super.logPrint.printBusinessErrorLog("EKKB0100AE", new String[] {"データ抽出項目設定更新対象ファイル"});
			// エラーフラグ設定
			super.commonItem.setErrFlg(true);
			return null;
		}

		// 単項目チェック関数呼出
		if (!isSingleCheckKKIFM198_INF1(inMap.getMap(), getItemvalue()))
		{
			// エラーフラグ設定
			super.commonItem.setErrFlg(true);
			// 出力情報を返却
			return new JBSbatOutputItem();
		}

		/** 入力情報の設定 **/
		AplyCnt = inMap.getString(JBSbatKKIFM198.KK1351_APLY_CNT);			// 適用数
		ChshtCnt = inMap.getString(JBSbatKKIFM198.KK1391_CHSHT_CNT);		// 抽出回数
		DchskmstNo = inMap.getString(JBSbatKKIFM198.KK1391_DCHSKMST_NO);	// データ抽出項目設定番号
		GeneAddDtm = inMap.getString(JBSbatKKIFM198.KK1391_GENE_ADD_DTM);	// 世代登録年月日時分秒
		UpdDtm = inMap.getString(JBSbatKKIFM198.KK1391_UPD_DTM);			// 更新年月日時分秒
		sysDateTime = JCCBatCommon.getSysDateTimeStamp();					// システム日付を取得
		
		/** タイムスタンプチェックを行う*/
		// データ抽出項目設定より最終更新日時を取得します。
		String upddtmAt = searchSvkeiExcCtrl();
		// タイムスタンプチェックOKの場合はレコードの排他処理も行う
		if(null == isTimeStampCheck(upddtmAt))
		{
			super.logPrint.printBusinessErrorLog("データ抽出項目設定更新処理で排他エラーが発生しました。"
					+ "{DCHSKMST_NO:" + this.DchskmstNo + " GENE_ADD_DTM:" + this.GeneAddDtm + "}");
			return null;
		}
		/** データ抽出項目設定更新処理を行う **/
		if ( Integer.parseInt(ChshtCnt) + 1 ==  Integer.parseInt(AplyCnt) ) {
		// ＋１した抽出回数がデータ抽出項目・適用数と同数となる場合

			// パラメータの設定
			Object[] setParam = {
					this.sysDateTime,	// 世代登録年月日時分秒
					super.opeDate,   	// 運用日
					this.sysDateTime,	// 登録年月日時分秒
					super.batchUserId,	// 登録オペレータアカウント（バッチユーザID）
					this.sysDateTime,	// 更新年月日時分秒
					super.batchUserId,	// 更新オペレータアカウント（バッチユーザID）
					this.DchskmstNo,   	// データ抽出項目設定番号
					this.GeneAddDtm   	// 世代登録年月日時分秒
			};
			// データ抽出項目設定更新
			executeKK_T_DCHSKMST_KK_INSERT_002(setParam);

		} else {
		// ＋１した抽出回数がデータ抽出項目・適用数と同数とならない場合

			// パラメータの設定
			Object[] setParam = {
					this.sysDateTime,	// 世代登録年月日時分秒
					this.sysDateTime,	// 登録年月日時分秒
					super.batchUserId,	// 登録オペレータアカウント（バッチユーザID）
					this.sysDateTime,	// 更新年月日時分秒
					super.batchUserId,	// 更新オペレータアカウント（バッチユーザID）
					this.DchskmstNo,   	// データ抽出項目設定番号
					this.GeneAddDtm   	// 世代登録年月日時分秒
			};
			// データ抽出項目設定更新
			executeKK_T_DCHSKMST_KK_INSERT_003(setParam);

		}
		super.logPrint.printDebugLog("execute_END");
		return null;
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		// DBアクセスクラスをクローズします
		db_KK_T_DCHSKMST.close();
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	/**
	 *入力情報（データ抽出項目設定更新対象ファイル）の単項目チェックを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.単項目チェックを行います。<br>
	 * 
	 * 2.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		rsMap:(項目、値)を(key、value)として、データをrsMapに入れます
	 *		itemvalueMap:埋め込み文字の値をitemvalueMapに入れます。キーの値は、以下に説明します。
	 *			 TXT-KKIFM198-INF1.KK1351_APLY_CNT			データ抽出項目設定更新対象ファイル.ＫＫ１３５１＿適用数
	 *			 TXT-KKIFM198-INF1.KK1351_APLY_CNT			データ抽出項目設定更新対象ファイル.ＫＫ１３５１＿適用数
	 *			 TXT-KKIFM198-INF1.KK1351_APLY_CNT			データ抽出項目設定更新対象ファイル.ＫＫ１３５１＿適用数
	 *			 TXT-KKIFM198-INF1.KK1391_CHSHT_CNT			データ抽出項目設定更新対象ファイル.ＫＫ１３９１＿抽出回数
	 *			 TXT-KKIFM198-INF1.KK1391_CHSHT_CNT			データ抽出項目設定更新対象ファイル.ＫＫ１３９１＿抽出回数
	 *			 TXT-KKIFM198-INF1.KK1391_CHSHT_CNT			データ抽出項目設定更新対象ファイル.ＫＫ１３９１＿抽出回数
	 *			 TXT-KKIFM198-INF1.KK1391_DCHSKMST_NO			データ抽出項目設定更新対象ファイル.ＫＫ１３９１＿データ抽出項目設定番号
	 *			 TXT-KKIFM198-INF1.KK1391_DCHSKMST_NO			データ抽出項目設定更新対象ファイル.ＫＫ１３９１＿データ抽出項目設定番号
	 *			 TXT-KKIFM198-INF1.KK1391_DCHSKMST_NO			データ抽出項目設定更新対象ファイル.ＫＫ１３９１＿データ抽出項目設定番号
	 *			 TXT-KKIFM198-INF1.KK1391_GENE_ADD_DTM			データ抽出項目設定更新対象ファイル.ＫＫ１３９１＿世代登録年月日時分秒
	 *			 TXT-KKIFM198-INF1.KK1391_GENE_ADD_DTM			データ抽出項目設定更新対象ファイル.ＫＫ１３９１＿世代登録年月日時分秒
	 *			 TXT-KKIFM198-INF1.KK1391_GENE_ADD_DTM			データ抽出項目設定更新対象ファイル.ＫＫ１３９１＿世代登録年月日時分秒
	 *			 TXT-KKIFM198-INF1.KK1391_UPD_DTM			データ抽出項目設定更新対象ファイル.ＫＫ１３９１＿更新年月日時分秒
	 *			 TXT-KKIFM198-INF1.KK1391_UPD_DTM			データ抽出項目設定更新対象ファイル.ＫＫ１３９１＿更新年月日時分秒
	 *			 TXT-KKIFM198-INF1.KK1391_UPD_DTM			データ抽出項目設定更新対象ファイル.ＫＫ１３９１＿更新年月日時分秒
	 * </pre>
	 * <p>
	 * @param rsMap 入力データ（TXT又はDB）を格納されたHashMap。
	 * @param itemvalueMap エラーメッセージに関する項目値を格納されたHashMap。
	 * @return  boolean trueである場合、エラーがありません。falseである場合、エラーを発生しました。
	 */
	private boolean isSingleCheckKKIFM198_INF1(HashMap rsMap, HashMap itemvalueMap)
	{
		// 単項目チェックを行います
		String strValue = null;

		// ＫＫ１３５１＿適用数項目チェック
		strValue = (String)rsMap.get("KK1351_APLY_CNT");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0060TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM198-INF1.KK1351_APLY_CNT")});
			return false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"double_chk", "12", "0"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0070TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM198-INF1.KK1351_APLY_CNT")});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0080TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM198-INF1.KK1351_APLY_CNT")});
			return false;
		}

		// ＫＫ１３９１＿抽出回数項目チェック
		strValue = (String)rsMap.get("KK1391_CHSHT_CNT");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0060TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM198-INF1.KK1391_CHSHT_CNT")});
			return false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"double_chk", "12", "0"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0070TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM198-INF1.KK1391_CHSHT_CNT")});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0080TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM198-INF1.KK1391_CHSHT_CNT")});
			return false;
		}

		// ＫＫ１３９１＿データ抽出項目設定番号項目チェック
		strValue = (String)rsMap.get("KK1391_DCHSKMST_NO");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0060TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM198-INF1.KK1391_DCHSKMST_NO")});
			return false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "12"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0070TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM198-INF1.KK1391_DCHSKMST_NO")});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0080TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM198-INF1.KK1391_DCHSKMST_NO")});
			return false;
		}

		// ＫＫ１３９１＿世代登録年月日時分秒項目チェック
		strValue = (String)rsMap.get("KK1391_GENE_ADD_DTM");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0060TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM198-INF1.KK1391_GENE_ADD_DTM")});
			return false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "17"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0070TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM198-INF1.KK1391_GENE_ADD_DTM")});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"day_hour1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0080TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM198-INF1.KK1391_GENE_ADD_DTM")});
			return false;
		}

		// ＫＫ１３９１＿更新年月日時分秒項目チェック
		strValue = (String)rsMap.get("KK1391_UPD_DTM");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0060TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM198-INF1.KK1391_UPD_DTM")});
			return false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "17"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0070TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM198-INF1.KK1391_UPD_DTM")});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"day_hour1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0080TE", new String[]{
															(String)itemvalueMap.get("TXT-KKIFM198-INF1.KK1391_UPD_DTM")});
			return false;
		}

		return true;
	}

	/**
	 * SQLKEY(KK_INSERT_002)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	世代登録年月日時分秒
	 *		 	データ抽出項目設定終了年月日
	 *		 	登録年月日時分秒
	 *		 	登録オペレータアカウント
	 *		 	更新年月日時分秒
	 *		 	更新オペレータアカウント
	 *		 	データ抽出項目設定番号
	 *		 	世代登録年月日時分秒
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeKK_T_DCHSKMST_KK_INSERT_002(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());
		paramList.setValue(param[1].toString());
		paramList.setValue(param[2].toString());
		paramList.setValue(param[3].toString());
		paramList.setValue(param[4].toString());
		paramList.setValue(param[5].toString());
		paramList.setValue(param[6].toString());
		paramList.setValue(param[7].toString());

		// DBアクセスを実行します
		db_KK_T_DCHSKMST.executeBySqlDefine(paramList, KK_T_DCHSKMST_KK_INSERT_002);
	}

	/**
	 * SQLKEY(KK_INSERT_003)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	世代登録年月日時分秒
	 *		 	登録年月日時分秒
	 *		 	登録オペレータアカウント
	 *		 	更新年月日時分秒
	 *		 	更新オペレータアカウント
	 *		 	データ抽出項目設定番号
	 *		 	世代登録年月日時分秒
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeKK_T_DCHSKMST_KK_INSERT_003(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());
		paramList.setValue(param[1].toString());
		paramList.setValue(param[2].toString());
		paramList.setValue(param[3].toString());
		paramList.setValue(param[4].toString());
		paramList.setValue(param[5].toString());
		paramList.setValue(param[6].toString());

		// DBアクセスを実行します
		db_KK_T_DCHSKMST.executeBySqlDefine(paramList, KK_T_DCHSKMST_KK_INSERT_003);
	}
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/

	/**
	 * 入力情報（データ抽出項目設定更新対象ファイル）の単項目チェック用<br>
	 * エラーメッセージに関する項目値を格納されたHashMap<String, String>を生成します。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.エラーメッセージに関する項目値を格納されたHashMapを生成する。<br>
	 *
	 * 2.エラーメッセージに関する項目値を格納されたHashMapに値を設定する。<br>
	 * </pre>
	 * <p>
	 * @return itemvalueMap エラーメッセージに関する項目値を格納されたHashMap
	 */
	private HashMap<String, String> getItemvalue()
	{
		// エラーメッセージに関する項目値が格納されたHashMapを設定
		HashMap<String, String> itemvalue_Map = new HashMap<String, String>();
		//--v1.00.01 mod Start-------------------------------------------------------------------------//
//		itemvalue_Map.put("TXT-KKIFM198-INF1.APLY_CNT",		"データ抽出項目設定更新対象ファイル.適用数");
//		itemvalue_Map.put("TXT-KKIFM198-INF1.CHSHT_CNT",	"データ抽出項目設定更新対象ファイル.抽出回数");
//		itemvalue_Map.put("TXT-KKIFM198-INF1.DCHSKMST_NO",	"データ抽出項目設定更新対象ファイル.データ抽出項目設定番号");
//		itemvalue_Map.put("TXT-KKIFM198-INF1.GENE_ADD_DTM",	"データ抽出項目設定更新対象ファイル.世代登録年月日時分秒");
//		itemvalue_Map.put("TXT-KKIFM198-INF1.UPD_DTM",		"データ抽出項目設定更新対象ファイル.更新年月日時分秒");
		itemvalue_Map.put("TXT-KKIFM198-INF1.KK1351_APLY_CNT",		"データ抽出項目設定更新対象ファイル.適用数");
		itemvalue_Map.put("TXT-KKIFM198-INF1.KK1391_CHSHT_CNT",	"データ抽出項目設定更新対象ファイル.抽出回数");
		itemvalue_Map.put("TXT-KKIFM198-INF1.KK1391_DCHSKMST_NO",	"データ抽出項目設定更新対象ファイル.データ抽出項目設定番号");
		itemvalue_Map.put("TXT-KKIFM198-INF1.KK1391_GENE_ADD_DTM",	"データ抽出項目設定更新対象ファイル.世代登録年月日時分秒");
		itemvalue_Map.put("TXT-KKIFM198-INF1.KK1391_UPD_DTM",		"データ抽出項目設定更新対象ファイル.更新年月日時分秒");
		//--v1.00.01 add End  -------------------------------------------------------------------------//

		return itemvalue_Map;
	}

	/**
	 * データ抽出項目設定の検索を行います。
	 * <br>
	 * @param なし
	 * @throws Exception 
	 */
	private String searchSvkeiExcCtrl() throws Exception
	{
		// SQL実行結果取得用mapを生成（サービス契約TBL）
		JBSbatCommonDBInterface pkMap = new JBSbatCommonDBInterface();

		// 条件項目を設定します
		pkMap.setValue(JBSbatKK_T_DCHSKMST.DCHSKMST_NO, this.DchskmstNo);
		pkMap.setValue(JBSbatKK_T_DCHSKMST.GENE_ADD_DTM,this.GeneAddDtm);
		super.logPrint.printDebugLog("pkParam(データ抽出項目設定番号)：：：：：：" + this.DchskmstNo);
		super.logPrint.printDebugLog("pkParam(世代登録年月日時分秒)：：：：：：" + this.GeneAddDtm);

		// PK検索を行う
		JBSbatCommonDBInterface outMap = db_KK_T_DCHSKMST.selectByPrimaryKeys(pkMap);

		return outMap.getString(JBSbatKK_T_DCHSKMST.UPD_DTM);
	}

	/**
	 * タイムスタンプチェックを実施します。
	 * <br>
	 * @param UpdDtmAf 最終更新年月日時分秒。
	 * @throws Exception 
	 */
	private JBSbatCommonDBInterface isTimeStampCheck(String UpdDtmAf) throws Exception
	{
		// ログレベルがデバッグモードの場合
		if(super.logPrint.chkLogLevel(JBSbatLogUtil.MODE_DEBUG))
		{
			super.logPrint.printDebugLog("更新年月日時分秒(初期検索)：" + UpdDtm);
			super.logPrint.printDebugLog("更新年月日時分秒(直前値)::：" + UpdDtmAf);
		}

		// タイムスタンプチェックの実施。
		if(UpdDtmAf.equals(UpdDtm))
		{
			JBSbatCommonDBInterface pkMap = new JBSbatCommonDBInterface();

			// テーブルに排他制御処理を実行する
			pkMap.setValue(JBSbatKK_T_DCHSKMST.DCHSKMST_NO, this.DchskmstNo);
			pkMap.setValue(JBSbatKK_T_DCHSKMST.GENE_ADD_DTM, this.GeneAddDtm);
			JBSbatCommonDBInterface dbmap = db_KK_T_DCHSKMST.selectByPrimaryKeysForUpdateWait(pkMap);

			if(super.logPrint.chkLogLevel(JBSbatLogUtil.MODE_DEBUG))
			{
				super.logPrint.printDebugLog("タイムスタンプチェック結果_OK");
			}
			return dbmap;
		}

		if(super.logPrint.chkLogLevel(JBSbatLogUtil.MODE_DEBUG))
		{
			super.logPrint.printDebugLog("タイムスタンプチェック結果_NG");
		}
		return null;
	}
}
