/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatKKIsetukjTnkjFinFix
*	ソースファイル名	：JBSbatKKIsetukjTnkjFinFix.java
*	作成者				：富士通　
*	作成日				：2012年05月24日
*＜機能概要＞
*　移設工事・宅内工事完了確定処理部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v3.00.00	2012/05/24  FJ)倉上		新規作成
*	v3.01.00	2012/11/28  FJ)柳		【IT1-2012-0002267】スキマ変更対応
*	v4.00.00	2013/04/01  FJ)柳		【IT1-2012-0000701】障害対応
*	v4.01.00	2013/06/11	FJ)小野		【LT-2013-0000025】進捗.異動年月日時分秒の設定値を共通部品より取得
*********************************************************************/
package eo.business.service;

import eo.business.common.JBSbatBusinessService;
import eo.business.common.JKKBatCommon;
import eo.business.util.table.JBSbatKK_T_KJ_FIN_WK;
import eo.business.util.table.JBSbatKK_T_SVC_KEI;
import eo.business.util.table.JBSbatKK_T_SVKEI_EXC_CTRL;
import eo.framework.application.JBSbatBusinessException;
import eo.framework.db.JBSbatSQLAccess;
import eo.framework.item.JBSbatCommonDBInterface;
import eo.framework.item.JBSbatCommonItem;
import eo.framework.item.JBSbatOutputItem;
import eo.framework.log.JBSbatLogUtil;
import eo.framework.util.JBSbatDateUtil;
import eo.framework.util.JBSbatOracleSeqUtil;
import eo.framework.util.JBSbatStringUtil;

/**
* (クラスの機能概要) <p>
*<BR>
* @author 富士通
*/
public class JBSbatKKIsetukjTnkjFinFix extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/** テーブル(工事完了ワーク)*/
	private static final String D_TBL_NAME_KK_T_KJ_FIN_WK = "KK_T_KJ_FIN_WK";

	/** テーブル(工事取消ワーク)*/
	private static final String D_TBL_NAME_KK_T_KJ_CL_WK = "KK_T_KJ_CL_WK";

	/** テーブル(サービス契約排他制御)*/
	private static final String D_TBL_NAME_KK_T_SVKEI_EXC_CTRL = "KK_T_SVKEI_EXC_CTRL";

	/** テーブル(サービス契約)*/
	private static final String D_TBL_NAME_KK_T_SVC_KEI = "KK_T_SVC_KEI";

	/** テーブル(進捗)*/
	private static final String D_TBL_NAME_KK_T_PRG = "KK_T_PRG";

	/** SQL定義キー(KK_SELECT_016)*/
	private static final String KK_T_KJ_FIN_WK_KK_SELECT_016 = "KK_SELECT_016";

	/** SQL定義キー(KK_SELECT_002)*/
	private static final String KK_T_KJ_CL_WK_KK_SELECT_002 = "KK_SELECT_002";

	/** テーブルアクセスクラス(工事完了ワーク)*/
	private JBSbatSQLAccess db_KK_T_KJ_FIN_WK = null;

	/** テーブルアクセスクラス(工事取消ワーク)*/
	private JBSbatSQLAccess db_KK_T_KJ_CL_WK = null;

	/** テーブルアクセスクラス(サービス契約排他制御)*/
	private JBSbatSQLAccess db_KK_T_SVKEI_EXC_CTRL = null;

	/** テーブルアクセスクラス(サービス契約)*/
	private JBSbatSQLAccess db_KK_T_SVC_KEI = null;

	/** テーブルアクセスクラス(進捗)*/
	private JBSbatSQLAccess db_KK_T_PRG = null;
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/
	
	/** テーブルアクセスクラス(共通部品)*/
	private JBSbatSQLAccess stmt = null;
	
	/** シーケンス定義名(SEQ_PRG_NO)*/
	private static final String SEQ_PRG_NO = "SEQ_PRG_NO";

	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);

		// DBアクセスクラスを生成します
		db_KK_T_KJ_FIN_WK = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KK_T_KJ_FIN_WK);
		db_KK_T_KJ_CL_WK = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KK_T_KJ_CL_WK);
		db_KK_T_SVKEI_EXC_CTRL = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KK_T_SVKEI_EXC_CTRL);
		db_KK_T_SVC_KEI = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KK_T_SVC_KEI);
		db_KK_T_PRG = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KK_T_PRG);
		
		// 共通部品用
		stmt = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KK_T_PRG);
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		
		super.logPrint.printDebugLog("execute_START");
		
		// 工事完了ワークを検索します。
		getKjFinWk();
		
		// 工事取消ワークを検索します。
		getKjClWk();
		
		// サービス契約情報登録
		addServiceKeiyakuInfo();
		
		super.logPrint.printDebugLog("execute_END");
		
		return null;
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		// DBアクセスクラスをクローズします
		db_KK_T_KJ_FIN_WK.close();
		db_KK_T_KJ_CL_WK.close();
		db_KK_T_SVKEI_EXC_CTRL.close();
		db_KK_T_SVC_KEI.close();
		db_KK_T_PRG.close();
		
		// 共通部品用
		stmt.close();
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	
	/**
	 * SQLKEY(KK_SELECT_016)で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_KJ_FIN_WK_KK_SELECT_016(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());

		// DBアクセスを実行します
		db_KK_T_KJ_FIN_WK.selectBySqlDefine(paramList, KK_T_KJ_FIN_WK_KK_SELECT_016);
	}

	/**
	 * SQLKEY(KK_SELECT_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_KJ_CL_WK_KK_SELECT_002(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());

		// DBアクセスを実行します
		db_KK_T_KJ_CL_WK.selectBySqlDefine(paramList, KK_T_KJ_CL_WK_KK_SELECT_002);
	}

	/**
	 * PK(ＰＫ　検索)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数で条件マップを作ります。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		whereParam:PK項目の(項目、値)を(key、value)として,格納された配列です。PK項目は以下に説明します。
	 *		 	SVC_KEI_NO
	 * </pre>
	 * <p>
	 * @param whereParam 条件項目の値。
	 * @return JBSbatCommonDBInterface 検索の結果。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private JBSbatCommonDBInterface executeKK_T_SVKEI_EXC_CTRL_PKSELECT(Object[] whereParam) throws Exception
	{
		// 条件のマップを作成します
		JBSbatCommonDBInterface whereMap = new JBSbatCommonDBInterface();
		whereMap.setValue("SVC_KEI_NO", whereParam[0]);

		// DBアクセスを実行します
		return db_KK_T_SVKEI_EXC_CTRL.selectByPrimaryKeys(whereMap);
	}

	/**
	 * PK(ＰＫ　検索)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数で条件マップを作ります。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		whereParam:PK項目の(項目、値)を(key、value)として,格納された配列です。PK項目は以下に説明します。
	 *		 	SVC_KEI_NO
	 *		 	GENE_ADD_DTM
	 * </pre>
	 * <p>
	 * @param whereParam 条件項目の値。
	 * @return JBSbatCommonDBInterface 検索の結果。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private JBSbatCommonDBInterface executeKK_T_SVC_KEI_PKSELECT(Object[] whereParam) throws Exception
	{
		// 条件のマップを作成します
		JBSbatCommonDBInterface whereMap = new JBSbatCommonDBInterface();
		whereMap.setValue("SVC_KEI_NO", whereParam[0]);
		whereMap.setValue("GENE_ADD_DTM", whereParam[1]);

		// DBアクセスを実行します
		return db_KK_T_SVC_KEI.selectByPrimaryKeys(whereMap);
	}

	/**
	 * PK(全項目登録)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数で設定項目マップを作ります。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		setParam:設定したい項目の(項目、値)を(key、value)として、setParamマップに入れます。項目キーは以下に説明します。
	 *		 	サービス契約番号				SVC_KEI_NO
	 *		 	世代登録年月日時分秒				GENE_ADD_DTM
	 *		 	サービス契約ステータス				SVC_KEI_STAT
	 *		 	ＳＹＳＩＤ				SYSID
	 *		 	サービスコード				SVC_CD
	 *		 	申込明細番号				MSKM_DTL_NO
	 *		 	整理番号				SEIRI_NO
	 *		 	面開発案件番号				MENKAIHAT_ANKEN_NO
	 *		 	料金グループコード				PRC_GRP_CD
	 *		 	料金コースコード				PCRS_CD
	 *		 	料金プランコード				PPLAN_CD
	 *		 	提供方式契約番号				TK_HOSHIKI_KEI_NO
	 *		 	サービス利用開始希望年月日				SVC_USE_STA_KIBO_YMD
	 *		 	予約適用開始希望年月日				RSV_TSTA_KIBO_YMD
	 *		 	ＩＤ速報書出力要否				ID_SOKHOSHO_OUTPUT_YH
	 *		 	サービス契約後続業務依頼年月日				SVC_KEI_KZKWRK_REQYMD
	 *		 	照査年月日				SHOSA_YMD
	 *		 	照査取消年月日				SHOSA_CL_YMD
	 *		 	審査結果コード				SKEKKA_CD
	 *		 	審査結果詳細コード				SKEKKA_DTL_CD
	 *		 	審査結果補記コード				SKEKKA_HOKI_CD
	 *		 	審査結果送信コード				SKEKKA_SEND_CD
	 *		 	支払い方法継続フラグ				PAYWAY_KEIZOKU_FLG
	 *		 	試用加入年月日				FTRIAL_KANYU_YMD
	 *		 	試用期間終了年月日				FTRIAL_PRD_ENDYMD
	 *		 	本加入年月日				HONKANYU_YMD
	 *		 	本加入移行期限年月日				HONKANYU_IKO_KIGEN_YMD
	 *		 	契約締結年月日				KEI_CNC_YMD
	 *		 	プラン開始年月日				PLAN_STAYMD
	 *		 	プラン終了年月日				PLAN_ENDYMD
	 *		 	プラン課金開始年月日				PLAN_CHRG_STAYMD
	 *		 	プラン課金終了年月日				PLAN_CHRG_ENDYMD
	 *		 	プラン終了種別コード				PLAN_END_SBT_CD
	 *		 	予約適用年月日				RSV_APLY_YMD
	 *		 	予約取消年月日				RSV_CL_YMD
	 *		 	予約適用コード				RSV_APLY_CD
	 *		 	サービスキャンセル年月日				SVC_CANCEL_YMD
	 *		 	サービスキャンセル理由コード				SVC_CANCEL_RSN_CD
	 *		 	サービス開始年月日				SVC_STA_YMD
	 *		 	サービス課金開始年月日				SVC_CHRG_STAYMD
	 *		 	継続サービス開始年月日				KEIZK_SVC_STAYMD
	 *		 	継続サービス課金開始年月日				KEIZK_SVC_CHRG_STAYMD
	 *		 	レター発送仕分区分				LETTER_HASSO_SHIWAKE_DIV
	 *		 	サンキューレター送付先コード				THNX_LETTER_SHS_CD
	 *		 	ＷＥＢオプション追加不可フラグ				WEB_OP_ADD_FAIL_FLG
	 *		 	サービス停止年月日				SVC_STP_YMD
	 *		 	サービス停止理由コード				SVC_STP_RSN_CD
	 *		 	サービス停止解除年月日				SVC_STP_RLS_YMD
	 *		 	サービス停止解除理由コード				SVC_STP_RLS_RSN_CD
	 *		 	休止中断コード				PAUSE_STP_CD
	 *		 	サービス休止年月日				SVC_PAUSE_YMD
	 *		 	サービス休止理由コード				SVC_PAUSE_RSN_CD
	 *		 	サービス休止理由メモ				SVC_PAUSE_RSN_MEMO
	 *		 	サービス休止解除年月日				SVC_PAUSE_RLS_YMD
	 *		 	サービス休止解除理由コード				SVC_PAUSE_RLS_RSN_CD
	 *		 	サービス休止解除理由メモ				SVC_PAUSE_RLS_RSN_MEMO
	 *		 	サービス終了年月日				SVC_ENDYMD
	 *		 	サービス課金終了年月日				SVC_CHRG_ENDYMD
	 *		 	サービス解約起算年月日				SVC_DSL_KISAN_YMD
	 *		 	サービス解約年月日				SVC_DSL_YMD
	 *		 	サービス解約理由コード				SVC_DLRE_CD
	 *		 	サービス解約理由メモ				SVC_DLRE_MEMO
	 *		 	サービス解約手続完了フラグ				SVC_DSL_TTDKI_FIN_FLG
	 *		 	回復年月日				KAIHK_YMD
	 *		 	サービスキャンセル取消年月日				SVC_CANCEL_CL_YMD
	 *		 	サービス解約取消年月日				SVC_DSL_CL_YMD
	 *		 	変更元法人サービス契約受付番号				CHGE_MT_HOJINSVKEI_UK_NO
	 *		 	変更元法人サービス契約受付番号子				CHGE_MT_HOJINSVKEI_UK_NOPT
	 *		 	変更先法人サービス契約受付番号				CHGE_SK_HOJINSVKEI_UK_NO
	 *		 	変更先法人サービス契約受付番号子				CHGE_SK_HOJINSVKEI_UK_NOPT
	 *		 	変更元法人ｅｏ読替サービス契約番号				CHMT_HJIN_EO_YKAE_SVKEI_NO
	 *		 	変更先法人ｅｏ読替サービス契約番号				CHSK_HJIN_EO_YKAE_SVKEI_NO
	 *		 	法人サービス契約引継ぎ種別コード				HOJINSVKEI_HKTGI_SBT_CD
	 *		 	違約金発生コード				PNLTY_HASSEI_CD
	 *		 	違約金変更理由コード				PNLTY_CHGE_RSN_CD
	 *		 	異動区分				IDO_DIV
	 *		 	初期デフォルトパスワード				SHK_DFLT_PWD
	 *		 	お客さまＩＤパスワード				CUST_ID_PWD
	 *		 	面開発案件仮登録フラグ				MENKAIHAT_ANKEN_KR_ADD_FLG
	 *		 	紹介コード				INTR_CD
	 *		 	照査解約完了コード				SHOSA_DSL_FIN_CD
	 *		 	異動ＮＧ状態コード				IDO_NG_STAT_CD
	 *		 	課金開始年月日補正有無				CHRG_STA_YMD_HOSEI_UM
	 *		 	サービス休止課金開始年月日				SVC_PAUSE_CHRG_STA_YMD
	 *		 	業務連絡備考				WORK_RRK_BIKO
	 *		 	自動照査処理状態コード				AUTO_SHOSA_TRAN_STAT_CD
	 *		 	機器未登録リスト出力済フラグ				KIKI_MIADD_LIST_OPUTZM_FLG
	 *		 	回復不可契約抽出済フラグ				KAIHK_FAIL_KEI_CST_ZM_FLG
	 *		 	サービス提供物消去処理実施年月日時分秒				SVCTK_BUT_DEL_TRN_JSSI_DTM
	 *			従量超過通知要否の取得			JURYO_CHOK_TCHI_YH 
	 *		 	登録年月日時分秒				ADD_DTM
	 *		 	登録オペレータアカウント				ADD_OPEACNT
	 *		 	更新年月日時分秒				UPD_DTM
	 *		 	更新オペレータアカウント				UPD_OPEACNT
	 *		 	削除年月日時分秒				DEL_DTM
	 *		 	削除オペレータアカウント				DEL_OPEACNT
	 *		 	無効フラグ				MK_FLG
	 *		 	登録運用年月日				ADD_UNYO_YMD
	 *		 	登録処理ＩＤ				ADD_TRN_ID
	 *		 	更新運用年月日				UPD_UNYO_YMD
	 *		 	更新処理ＩＤ				UPD_TRN_ID
	 *		 	削除運用年月日				DEL_UNYO_YMD
	 *		 	削除処理ＩＤ				DEL_TRN_ID
	 * </pre>
	 * <p>
	 * @param setParam 設定項目の値。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeKK_T_SVC_KEI_PKINSERT(Object[] setParam) throws Exception
	{
		// 設定値のマップを作成します
		JBSbatCommonDBInterface setMap = new JBSbatCommonDBInterface();
		setMap.setValue("SVC_KEI_NO", setParam[0]);
		setMap.setValue("GENE_ADD_DTM", setParam[1]);
		setMap.setValue("SVC_KEI_STAT", setParam[2]);
		setMap.setValue("SYSID", setParam[3]);
		setMap.setValue("SVC_CD", setParam[4]);
		setMap.setValue("MSKM_DTL_NO", setParam[5]);
		setMap.setValue("SEIRI_NO", setParam[6]);
		setMap.setValue("MENKAIHAT_ANKEN_NO", setParam[7]);
		setMap.setValue("PRC_GRP_CD", setParam[8]);
		setMap.setValue("PCRS_CD", setParam[9]);
		setMap.setValue("PPLAN_CD", setParam[10]);
		setMap.setValue("TK_HOSHIKI_KEI_NO", setParam[11]);
		setMap.setValue("SVC_USE_STA_KIBO_YMD", setParam[12]);
		setMap.setValue("RSV_TSTA_KIBO_YMD", setParam[13]);
		setMap.setValue("ID_SOKHOSHO_OUTPUT_YH", setParam[14]);
		setMap.setValue("SVC_KEI_KZKWRK_REQYMD", setParam[15]);
		setMap.setValue("SHOSA_YMD", setParam[16]);
		setMap.setValue("SHOSA_CL_YMD", setParam[17]);
		setMap.setValue("SKEKKA_CD", setParam[18]);
		setMap.setValue("SKEKKA_DTL_CD", setParam[19]);
		setMap.setValue("SKEKKA_HOKI_CD", setParam[20]);
		setMap.setValue("SKEKKA_SEND_CD", setParam[21]);
		setMap.setValue("PAYWAY_KEIZOKU_FLG", setParam[22]);
		setMap.setValue("FTRIAL_KANYU_YMD", setParam[23]);
		setMap.setValue("FTRIAL_PRD_ENDYMD", setParam[24]);
		setMap.setValue("HONKANYU_YMD", setParam[25]);
		setMap.setValue("HONKANYU_IKO_KIGEN_YMD", setParam[26]);
		setMap.setValue("KEI_CNC_YMD", setParam[27]);
		setMap.setValue("PLAN_STAYMD", setParam[28]);
		setMap.setValue("PLAN_ENDYMD", setParam[29]);
		setMap.setValue("PLAN_CHRG_STAYMD", setParam[30]);
		setMap.setValue("PLAN_CHRG_ENDYMD", setParam[31]);
		setMap.setValue("PLAN_END_SBT_CD", setParam[32]);
		setMap.setValue("RSV_APLY_YMD", setParam[33]);
		setMap.setValue("RSV_CL_YMD", setParam[34]);
		setMap.setValue("RSV_APLY_CD", setParam[35]);
		setMap.setValue("SVC_CANCEL_YMD", setParam[36]);
		setMap.setValue("SVC_CANCEL_RSN_CD", setParam[37]);
		setMap.setValue("SVC_STA_YMD", setParam[38]);
		setMap.setValue("SVC_CHRG_STAYMD", setParam[39]);
		setMap.setValue("KEIZK_SVC_STAYMD", setParam[40]);
		setMap.setValue("KEIZK_SVC_CHRG_STAYMD", setParam[41]);
		setMap.setValue("LETTER_HASSO_SHIWAKE_DIV", setParam[42]);
		setMap.setValue("THNX_LETTER_SHS_CD", setParam[43]);
		setMap.setValue("WEB_OP_ADD_FAIL_FLG", setParam[44]);
		setMap.setValue("SVC_STP_YMD", setParam[45]);
		setMap.setValue("SVC_STP_RSN_CD", setParam[46]);
		setMap.setValue("SVC_STP_RLS_YMD", setParam[47]);
		setMap.setValue("SVC_STP_RLS_RSN_CD", setParam[48]);
		setMap.setValue("PAUSE_STP_CD", setParam[49]);
		setMap.setValue("SVC_PAUSE_YMD", setParam[50]);
		setMap.setValue("SVC_PAUSE_RSN_CD", setParam[51]);
		setMap.setValue("SVC_PAUSE_RSN_MEMO", setParam[52]);
		setMap.setValue("SVC_PAUSE_RLS_YMD", setParam[53]);
		setMap.setValue("SVC_PAUSE_RLS_RSN_CD", setParam[54]);
		setMap.setValue("SVC_PAUSE_RLS_RSN_MEMO", setParam[55]);
		setMap.setValue("SVC_ENDYMD", setParam[56]);
		setMap.setValue("SVC_CHRG_ENDYMD", setParam[57]);
		setMap.setValue("SVC_DSL_KISAN_YMD", setParam[58]);
		setMap.setValue("SVC_DSL_YMD", setParam[59]);
		setMap.setValue("SVC_DLRE_CD", setParam[60]);
		setMap.setValue("SVC_DLRE_MEMO", setParam[61]);
		setMap.setValue("SVC_DSL_TTDKI_FIN_FLG", setParam[62]);
		setMap.setValue("KAIHK_YMD", setParam[63]);
		setMap.setValue("SVC_CANCEL_CL_YMD", setParam[64]);
		setMap.setValue("SVC_DSL_CL_YMD", setParam[65]);
		setMap.setValue("CHGE_MT_HOJINSVKEI_UK_NO", setParam[66]);
		setMap.setValue("CHGE_MT_HOJINSVKEI_UK_NOPT", setParam[67]);
		setMap.setValue("CHGE_SK_HOJINSVKEI_UK_NO", setParam[68]);
		setMap.setValue("CHGE_SK_HOJINSVKEI_UK_NOPT", setParam[69]);
		setMap.setValue("CHMT_HJIN_EO_YKAE_SVKEI_NO", setParam[70]);
		setMap.setValue("CHSK_HJIN_EO_YKAE_SVKEI_NO", setParam[71]);
		setMap.setValue("HOJINSVKEI_HKTGI_SBT_CD", setParam[72]);
		setMap.setValue("PNLTY_HASSEI_CD", setParam[73]);
		setMap.setValue("PNLTY_CHGE_RSN_CD", setParam[74]);
		setMap.setValue("IDO_DIV", setParam[75]);
		setMap.setValue("SHK_DFLT_PWD", setParam[76]);
		setMap.setValue("CUST_ID_PWD", setParam[77]);
		setMap.setValue("MENKAIHAT_ANKEN_KR_ADD_FLG", setParam[78]);
		setMap.setValue("INTR_CD", setParam[79]);
		setMap.setValue("SHOSA_DSL_FIN_CD", setParam[80]);
		setMap.setValue("IDO_NG_STAT_CD", setParam[81]);
		setMap.setValue("CHRG_STA_YMD_HOSEI_UM", setParam[82]);
		setMap.setValue("SVC_PAUSE_CHRG_STA_YMD", setParam[83]);
		setMap.setValue("WORK_RRK_BIKO", setParam[84]);
		setMap.setValue("AUTO_SHOSA_TRAN_STAT_CD", setParam[85]);
		setMap.setValue("KIKI_MIADD_LIST_OPUTZM_FLG", setParam[86]);
		setMap.setValue("KAIHK_FAIL_KEI_CST_ZM_FLG", setParam[87]);
		setMap.setValue("SVCTK_BUT_DEL_TRN_JSSI_DTM", setParam[88]);
		setMap.setValue("JURYO_CHOK_TCHI_YH", setParam[89]);
		setMap.setValue("ADD_DTM", setParam[90]);
		setMap.setValue("ADD_OPEACNT", setParam[91]);
		setMap.setValue("UPD_DTM", setParam[92]);
		setMap.setValue("UPD_OPEACNT", setParam[93]);
		setMap.setValue("DEL_DTM", setParam[94]);
		setMap.setValue("DEL_OPEACNT", setParam[95]);
		setMap.setValue("MK_FLG", setParam[96]);
		setMap.setValue("ADD_UNYO_YMD", setParam[97]);
		setMap.setValue("ADD_TRN_ID", setParam[98]);
		setMap.setValue("UPD_UNYO_YMD", setParam[99]);
		setMap.setValue("UPD_TRN_ID", setParam[100]);
		setMap.setValue("DEL_UNYO_YMD", setParam[101]);
		setMap.setValue("DEL_TRN_ID", setParam[102]);
		
		// DBアクセスを実行します
		db_KK_T_SVC_KEI.insertByPrimaryKeys(setMap);
	}

	/**
	 * PK(全項目登録)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数で設定項目マップを作ります。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		setParam:設定したい項目の(項目、値)を(key、value)として、setParamマップに入れます。項目キーは以下に説明します。
	 *		 	進捗番号				PRG_NO
	 *		 	申込明細番号				MSKM_DTL_NO
	 *		 	請求契約番号				SEIKY_KEI_NO
	 *		 	請求方法番号（口座）				SEIKY_WAY_NO_KOZA
	 *		 	請求方法番号（クレジットカード）				SEIKY_WAY_NO_CRECARD
	 *		 	サービス契約番号				SVC_KEI_NO
	 *		 	サービス契約内訳番号				SVC_KEI_UCWK_NO
	 *		 	サービス契約回線内訳番号				SVC_KEI_KAISEN_UCWK_NO
	 *		 	機器提供サービス契約番号				KKTK_SVC_KEI_NO
	 *		 	オプションサービス契約番号				OP_SVC_KEI_NO
	 *		 	請求オプションサービス契約番号				SEIOPSVC_KEI_NO
	 *		 	サブオプションサービス契約番号				SBOP_SVC_KEI_NO
	 *		 	割引サービス契約番号				WRIB_SVC_KEI_NO
	 *		 	異動区分				IDO_DIV
	 *		 	異動年月日時分秒				IDO_DTM
	 *		 	進捗ステータス				PRG_STAT
	 *		 	進捗年月日時分秒				PRG_DTM
	 *		 	進捗メモ				PRG_MEMO
	 *		 	進捗特記事項１				PRG_TKJK_1
	 *		 	進捗特記事項２				PRG_TKJK_2
	 *		 	登録年月日時分秒				ADD_DTM
	 *		 	登録オペレータアカウント				ADD_OPEACNT
	 *		 	更新年月日時分秒				UPD_DTM
	 *		 	更新オペレータアカウント				UPD_OPEACNT
	 *		 	削除年月日時分秒				DEL_DTM
	 *		 	削除オペレータアカウント				DEL_OPEACNT
	 *		 	無効フラグ				MK_FLG
	 *		 	登録運用年月日				ADD_UNYO_YMD
	 *		 	登録処理ＩＤ				ADD_TRN_ID
	 *		 	更新運用年月日				UPD_UNYO_YMD
	 *		 	更新処理ＩＤ				UPD_TRN_ID
	 *		 	削除運用年月日				DEL_UNYO_YMD
	 *		 	削除処理ＩＤ				DEL_TRN_ID
	 * </pre>
	 * <p>
	 * @param setParam 設定項目の値。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeKK_T_PRG_PKINSERT(Object[] setParam) throws Exception
	{
		// 設定値のマップを作成します
		JBSbatCommonDBInterface setMap = new JBSbatCommonDBInterface();
		setMap.setValue("PRG_NO", setParam[0]);
		setMap.setValue("MSKM_DTL_NO", setParam[1]);
		setMap.setValue("SEIKY_KEI_NO", setParam[2]);
		setMap.setValue("SEIKY_WAY_NO_KOZA", setParam[3]);
		setMap.setValue("SEIKY_WAY_NO_CRECARD", setParam[4]);
		setMap.setValue("SVC_KEI_NO", setParam[5]);
		setMap.setValue("SVC_KEI_UCWK_NO", setParam[6]);
		setMap.setValue("SVC_KEI_KAISEN_UCWK_NO", setParam[7]);
		setMap.setValue("KKTK_SVC_KEI_NO", setParam[8]);
		setMap.setValue("OP_SVC_KEI_NO", setParam[9]);
		setMap.setValue("SEIOPSVC_KEI_NO", setParam[10]);
		setMap.setValue("SBOP_SVC_KEI_NO", setParam[11]);
		setMap.setValue("WRIB_SVC_KEI_NO", setParam[12]);
		setMap.setValue("IDO_DIV", setParam[13]);
		setMap.setValue("IDO_DTM", setParam[14]);
		setMap.setValue("PRG_STAT", setParam[15]);
		setMap.setValue("PRG_DTM", setParam[16]);
		setMap.setValue("PRG_MEMO", setParam[17]);
		setMap.setValue("PRG_TKJK_1", setParam[18]);
		setMap.setValue("PRG_TKJK_2", setParam[19]);
		setMap.setValue("ADD_DTM", setParam[20]);
		setMap.setValue("ADD_OPEACNT", setParam[21]);
		setMap.setValue("UPD_DTM", setParam[22]);
		setMap.setValue("UPD_OPEACNT", setParam[23]);
		setMap.setValue("DEL_DTM", setParam[24]);
		setMap.setValue("DEL_OPEACNT", setParam[25]);
		setMap.setValue("MK_FLG", setParam[26]);
		setMap.setValue("ADD_UNYO_YMD", setParam[27]);
		setMap.setValue("ADD_TRN_ID", setParam[28]);
		setMap.setValue("UPD_UNYO_YMD", setParam[29]);
		setMap.setValue("UPD_TRN_ID", setParam[30]);
		setMap.setValue("DEL_UNYO_YMD", setParam[31]);
		setMap.setValue("DEL_TRN_ID", setParam[32]);
	
		// DBアクセスを実行します
		db_KK_T_PRG.insertByPrimaryKeys(setMap);
	}

//	/**
//	 * PK(ＰＫ　更新)でDBアクセスを行います。<br>
//	 * <p>
//	 * <b>処理フロー</b><br>
//	 * <pre>
//	 * 1.引数で設定項目マップを作ります。<br>
//	 *
//	 * 2.引数で条件マップを作ります。<br>
//	 *
//	 * 3.DBアクセスを実行します。<br>
//	 * 
//	 * 4.メソッドの呼び出し方です。<br>
//	 *		引数:
//	 *		setParam:設定したい項目の(項目、値)を(key、value)として、setParamマップに入れます。項目キーは以下に説明します。
//	 *		 	最終更新年月日時分秒				LAST_UPD_DTM
//	 *		whereParam:PK項目の(項目、値)を(key、value)として,格納された配列です。PK項目は以下に説明します。
//	 *		 	SVC_KEI_NO
//	 * </pre>
//	 * <p>
//	 * @param setParam 設定項目の値。
//	 * @param whereParam 条件項目の値。
//	 * @throws Exception 業務サービス内で発生した例外全般。
//	 */
//	private void executeKK_T_SVKEI_EXC_CTRL_PKUPDATE(Object[] setParam, Object[] whereParam) throws Exception
//	{
//		// 設定値のマップを作成します
//		JBSbatCommonDBInterface setMap = new JBSbatCommonDBInterface();
//		setMap.setValue("LAST_UPD_DTM", setParam[0]);
//	
//		// 条件のマップを作成します
//		JBSbatCommonDBInterface whereMap = new JBSbatCommonDBInterface();
//		whereMap.setValue("SVC_KEI_NO", whereParam[0]);
//
//		// DBアクセスを実行します
//		db_KK_T_SVKEI_EXC_CTRL.updateByPrimaryKeys(whereMap, setMap);
//	}
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/
	
	/**
	 * 工事完了ワーク情報検索
	 * 
	 * @throws Exception メソッド内で発生した例外全般。
	 */
	private void getKjFinWk() throws Exception 
	{
		// 検索条件の設定
		Object[] param = {super.opeDate};
		
		// 工事完了ワーク検索実施。
		executeKK_T_KJ_FIN_WK_KK_SELECT_016(param);
	}
	
	/**
	 * 工事取消ワーク情報検索
	 * 
	 * @throws Exception メソッド内で発生した例外全般。
	 */
	private void getKjClWk() throws Exception 
	{
		// 検索条件の設定
		Object[] param = {super.opeDate};
		
		// 工事取消ワーク検索実施。
		executeKK_T_KJ_CL_WK_KK_SELECT_002(param);
	}

	/**
	 * サービス契約情報登録
	 * 
	 * @throws Exception メソッド内で発生した例外全般。
	 */
	private void addServiceKeiyakuInfo() throws Exception 
	{
	
		// 検索結果の取得(工事完了ワーク)
		JBSbatCommonDBInterface kjfinMap = db_KK_T_KJ_FIN_WK.selectNext();
		
		while (null != kjfinMap)
		{
			// システム日時の取得
			String sysdate = JBSbatDateUtil.getSystemDateTimeStamp();
			
			// サービス契約番号の取得
			String svc_kei_no = JBSbatStringUtil.Rtrim(kjfinMap.getString(JBSbatKK_T_SVC_KEI.SVC_KEI_NO));
			
			// 世代登録年月日時分秒
			String gene_add_dtm = JBSbatStringUtil.Rtrim(kjfinMap.getString(JBSbatKK_T_SVC_KEI.GENE_ADD_DTM));
			
			// 更新年月日時分秒を取得します。
			String lastUpdDtmBf = JBSbatStringUtil.Rtrim(kjfinMap.getString(JBSbatKK_T_SVKEI_EXC_CTRL.LAST_UPD_DTM));
			
			// サービス契約排他制御より最終更新日時を取得し同じ場合排他をかけます。
			String lastUpdDtmAf = searchSvkeiExcCtrl(svc_kei_no, gene_add_dtm);
			if(null == this.timeStampCheck(svc_kei_no, lastUpdDtmAf, lastUpdDtmBf))
			{
				throw new JBSbatBusinessException("EKKB0360KE", new String[]{"サービス契約排他制御TBL", svc_kei_no});
			}
			
			// サービス契約情報の設定
			setServiceKeiyakuInfo(kjfinMap, sysdate, true);
			
			// 次のレコード取得
			kjfinMap = db_KK_T_KJ_FIN_WK.selectNext();
		}
		
		// 検索結果の取得(工事取消ワーク)
		JBSbatCommonDBInterface kjClMap = db_KK_T_KJ_CL_WK.selectNext();
		
		while (null != kjClMap)
		{
			// システム日時の取得
			String sysdate = JBSbatDateUtil.getSystemDateTimeStamp();
			
			// サービス契約番号の取得
			String svc_kei_no = JBSbatStringUtil.Rtrim(kjClMap.getString(JBSbatKK_T_SVC_KEI.SVC_KEI_NO));
			
			// 世代登録年月日時分秒
			String gene_add_dtm = JBSbatStringUtil.Rtrim(kjClMap.getString(JBSbatKK_T_SVC_KEI.GENE_ADD_DTM));
			
			// 更新年月日時分秒を取得します。
			String lastUpdDtmBf = JBSbatStringUtil.Rtrim(kjClMap.getString(JBSbatKK_T_SVKEI_EXC_CTRL.LAST_UPD_DTM));
			
			// サービス契約排他制御より最終更新日時を取得し同じ場合排他をかけます。
			String lastUpdDtmAf = searchSvkeiExcCtrl(svc_kei_no, gene_add_dtm);
			if(null == this.timeStampCheck(svc_kei_no, lastUpdDtmAf, lastUpdDtmBf))
			{
				throw new JBSbatBusinessException("EKKB0360KE", new String[]{"サービス契約排他制御TBL", svc_kei_no});
			}
			
			// サービス契約情報の設定
			setServiceKeiyakuInfo(kjClMap, sysdate, false);
			
			// 次のレコード取得
			kjClMap = db_KK_T_KJ_CL_WK.selectNext();
		}
	}
	
	/**
	 * サービス契約排他制御テーブルの検索を行います。
	 * <br>
	 * @param  svc_kei_no サービス契約番号
	 * @param  gene_add_dtm 世代登録年月日時分秒
	 * @return 最終更新年月日時分秒
	 * @throws Exception 
	 */
	private String searchSvkeiExcCtrl(String svc_kei_no, String gene_add_dtm) throws Exception
	{
		// 条件項目を設定します
		Object[] whereParam = {svc_kei_no};
		super.logPrint.printDebugLog("pkParam(ｻｰﾋﾞｽ契約番号)：：：：：：" +  svc_kei_no);
		
		// PK検索を行う
		JBSbatCommonDBInterface outMap = executeKK_T_SVKEI_EXC_CTRL_PKSELECT(whereParam);
		
		if(null == outMap)
		{
			return "";
		}
		
		return outMap.getString(JBSbatKK_T_SVKEI_EXC_CTRL.LAST_UPD_DTM);
	}
	
	/**
	 * サービス契約排他制御への更新処理を行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.更新処理を実行します。<br>
	 * 
	 * </pre>
	 * <p>
	 * @param  svc_kei_no サービス契約番号。
	 * @param  sysdate システム日付。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void upDateSvkeiExcCtrl(String svc_kei_no, String  sysdate) throws Exception
	{
		// サービス契約排他制御の最終更新年月日時分秒の更新を行う。
		JBSbatCommonDBInterface paramMap = new JBSbatCommonDBInterface();
		JBSbatCommonDBInterface whereMap = new JBSbatCommonDBInterface();
		
		// サービス契約番号を設定
		whereMap.setValue(JBSbatKK_T_SVKEI_EXC_CTRL.SVC_KEI_NO, svc_kei_no);
		
		// 最終更新年月日時分秒を更新。
		paramMap.setValue(JBSbatKK_T_SVKEI_EXC_CTRL.LAST_UPD_DTM, sysdate);
		db_KK_T_SVKEI_EXC_CTRL.updateByPrimaryKeys(whereMap, paramMap);
	}
	
	/**
	 * タイムスタンプチェックを実施します。
	 * <br>
	 * @param svc_kei_no サービス契約番号。
	 * @param lastUpdDtmAf 最終更新年月日時分秒。
	 * @param lastUpdDtmBf 世代登録年月日時分秒。
	 * @return タイムスタンプチェック結果
	 * @throws Exception 
	 */
	private JBSbatCommonDBInterface timeStampCheck(String svc_kei_no, String lastUpdDtmAf, String lastUpdDtmBf) throws Exception
	{
		// ログレベルがデバッグモードの場合
		if(super.logPrint.chkLogLevel(JBSbatLogUtil.MODE_DEBUG))
		{
			super.logPrint.printDebugLog("更新年月日時分秒(初期検索)：" + lastUpdDtmBf);
			super.logPrint.printDebugLog("更新年月日時分秒(直前値)::：" + lastUpdDtmAf);
		}
		
		// タイムスタンプチェックの実施。
		if(lastUpdDtmAf.equals(lastUpdDtmBf))
		{
			JBSbatCommonDBInterface svkeiExcCtrlMap = new JBSbatCommonDBInterface();
			
			// サービス契約排他制御テーブルに排他制御処理を実行する
			svkeiExcCtrlMap.setValue(JBSbatKK_T_SVKEI_EXC_CTRL.SVC_KEI_NO, svc_kei_no);
			JBSbatCommonDBInterface dbmap = db_KK_T_SVKEI_EXC_CTRL.selectByPrimaryKeysForUpdateWait(svkeiExcCtrlMap);
			
			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;
	}
	
	/**
	 * 
	 * サービス契約情報登録。
	 * 
	 * @param outMap  工事完了ワーク又は工事取消ワーク情報。
	 * @param sysdate システム日付。
	 * @param flg     工事完了ワーク又は工事取消ワーク情報の区別
	 * @throws Exception メソッド内で発生した例外全般。
	 */
	private void setServiceKeiyakuInfo(JBSbatCommonDBInterface outMap, String sysdate, boolean flg) throws Exception 
	{
		// サービス契約番号の取得
		String svc_kei_no = JBSbatStringUtil.Rtrim(outMap.getString(JBSbatKK_T_SVC_KEI.SVC_KEI_NO));
		
		// 世代登録年月日時分秒
		String gene_add_dtm = JBSbatStringUtil.Rtrim(outMap.getString(JBSbatKK_T_SVC_KEI.GENE_ADD_DTM));
		
		// キー検索によりサービス契約情報を取得します。
		Object[] whereParam = {svc_kei_no, gene_add_dtm};
		
		// サービス契約情報取得
		JBSbatCommonDBInterface svkeiMap = executeKK_T_SVC_KEI_PKSELECT(whereParam);
		
		String [] setParam = {
				svc_kei_no,																					// サービス契約番号の取得
				sysdate,																					// システム日時の設定
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_KEI_STAT)),				// サービス契約ステータスの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SYSID)),						// SYSIDの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_CD)),						// サービスコードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.MSKM_DTL_NO)),					// 申込明細番号の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SEIRI_NO)),					// 整理番号の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.MENKAIHAT_ANKEN_NO)),			// 面開発案件番号の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.PRC_GRP_CD)),					// 料金グループコードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.PCRS_CD)),						// 料金コースコードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.PPLAN_CD)),					// 料金プランコードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.TK_HOSHIKI_KEI_NO)),			// 提供方式契約番号の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_USE_STA_KIBO_YMD)),		// サービス利用開始希望年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.RSV_TSTA_KIBO_YMD)),			// 予約適用開始希望年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.ID_SOKHOSHO_OUTPUT_YH)),		// ID速報書出力要否の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_KEI_KZKWRK_REQYMD)),		// サービス契約後続業務依頼年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SHOSA_YMD)),					// 照査年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SHOSA_CL_YMD)),				// 照査取消年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SKEKKA_CD)),					// 審査結果コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SKEKKA_DTL_CD)),				// 審査結果詳細コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SKEKKA_HOKI_CD)),				// 審査結果補記コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SKEKKA_SEND_CD)),				// 審査結果送信コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.PAYWAY_KEIZOKU_FLG)),			// 支払い方法継続フラグの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.FTRIAL_KANYU_YMD)),			// 試用加入年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.FTRIAL_PRD_ENDYMD)),			// 試用期間終了年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.HONKANYU_YMD)),				// 本加入年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.HONKANYU_IKO_KIGEN_YMD)),		// 本加入移行期限年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.KEI_CNC_YMD)),					// 契約締結年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.PLAN_STAYMD)),					// プラン開始年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.PLAN_ENDYMD)),					// プラン終了年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.PLAN_CHRG_STAYMD)),			// プラン課金開始年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.PLAN_CHRG_ENDYMD)),			// プラン課金終了年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.PLAN_END_SBT_CD)),				// プラン終了種別コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.RSV_APLY_YMD)),				// 予約適用年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.RSV_CL_YMD)),					// 予約取消年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.RSV_APLY_CD)),					// 予約適用コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_CANCEL_YMD)),				// サービスキャンセル年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_CANCEL_RSN_CD)),			// サービスキャンセル理由コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_STA_YMD)),					// サービス開始年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_CHRG_STAYMD)),				// サービス課金開始年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.KEIZK_SVC_STAYMD)),			// 継続サービス開始年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.KEIZK_SVC_CHRG_STAYMD)),		// 継続サービス課金開始年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.LETTER_HASSO_SHIWAKE_DIV)),	// レター発送仕分区分の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.THNX_LETTER_SHS_CD)),			// サンキューレター送付先コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.WEB_OP_ADD_FAIL_FLG)),			// WEBオプション追加不可フラグの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_STP_YMD)),					// サービス停止年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_STP_RSN_CD)),				// サービス停止理由コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_STP_RLS_YMD)),				// サービス停止解除年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_STP_RLS_RSN_CD)),			// サービス停止解除理由コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.PAUSE_STP_CD)),				// 休止中断コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_PAUSE_YMD)),				// サービス休止年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_PAUSE_RSN_CD)),			// サービス休止理由コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_PAUSE_RSN_MEMO)),			// サービス休止理由メモの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_PAUSE_RLS_YMD)),			// サービス休止解除年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_PAUSE_RLS_RSN_CD)),		// サービス休止解除理由コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_PAUSE_RLS_RSN_MEMO)),		// サービス休止解除理由メモの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_ENDYMD)),					// サービス終了年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_CHRG_ENDYMD)),				// サービス課金終了年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_DSL_KISAN_YMD)),			// サービス解約起算年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_DSL_YMD)),					// サービス解約年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_DLRE_CD)),					// サービス解約理由コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_DLRE_MEMO)),				// サービス解約理由メモの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_DSL_TTDKI_FIN_FLG)),		// サービス解約手続完了フラグの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.KAIHK_YMD)),					// 回復年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_CANCEL_CL_YMD)),			// サービスキャンセル取消年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_DSL_CL_YMD)),				// サービス解約取消年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.CHGE_MT_HOJINSVKEI_UK_NO)),	// 変更元法人サービス契約受付番号の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.CHGE_MT_HOJINSVKEI_UK_NOPT)),	// 変更元法人サービス契約受付番号子の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.CHGE_SK_HOJINSVKEI_UK_NO)),	// 変更先法人サービス契約受付番号の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.CHGE_SK_HOJINSVKEI_UK_NOPT)),	// 変更先法人サービス契約受付番号子の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.CHMT_HJIN_EO_YKAE_SVKEI_NO)),	// 変更元法人eo読替サービス契約番号の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.CHSK_HJIN_EO_YKAE_SVKEI_NO)),	// 変更先法人eo読替サービス契約番号の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.HOJINSVKEI_HKTGI_SBT_CD)),		// 法人サービス契約引継ぎ種別コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.PNLTY_HASSEI_CD)),				// 違約金発生コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.PNLTY_CHGE_RSN_CD)),			// 違約金変更理由コードの取得
				getIdoDiv(outMap),																			// 異動区分の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SHK_DFLT_PWD)),				// 初期デフォルトパスワードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.CUST_ID_PWD)),					// お客さまIDパスワードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.MENKAIHAT_ANKEN_KR_ADD_FLG)),	// 面開発案件仮登録フラグの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.INTR_CD)),						// 紹介コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SHOSA_DSL_FIN_CD)),			// 照査解約完了コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.IDO_NG_STAT_CD)),				// 異動NG状態コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.CHRG_STA_YMD_HOSEI_UM)),		// 課金開始年月日補正有無の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVC_PAUSE_CHRG_STA_YMD)),		// サービス休止課金開始年月日の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.WORK_RRK_BIKO)),				// 業務連絡備考の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.AUTO_SHOSA_TRAN_STAT_CD)),		// 自動照査処理状態コードの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.KIKI_MIADD_LIST_OPUTZM_FLG)),	// 機器未登録リスト出力済フラグの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.KAIHK_FAIL_KEI_CST_ZM_FLG)),	// 回復不可契約抽出済フラグの取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.SVCTK_BUT_DEL_TRN_JSSI_DTM)),	// サービス提供物消去処理実施年月日時分秒の取得
				JBSbatStringUtil.Rtrim(svkeiMap.getString(JBSbatKK_T_SVC_KEI.JURYO_CHOK_TCHI_YH)),			// 従量超過通知要否の取得
				"",																							// 登録年月日時分秒の取得
				"",																							// 登録オペレータアカウントの取得
				"",																							// 更新年月日時分秒の取得
				"",																							// 更新オペレータアカウントの取得
				"",																							// 削除年月日時分秒の取得
				"",																							// 削除オペレータアカウントの取得
				"0",																						// 無効フラグの取得
				"",																							// 登録運用年月日の取得
				"",																							// 登録処理IDの取得
				"",																							// 更新運用年月日の取得
				"",																							// 更新処理IDの取得
				"",																							// 削除運用年月日の取得
				"",																							// 削除処理IDの取得
		};
		
		// 登録処理の実施。
		executeKK_T_SVC_KEI_PKINSERT(setParam);
		
		// サービス契約番号に紐づくサブクラスの登録を行います。
		JKKBatCommon.createSubTypeKK0081(commonItem, svc_kei_no, gene_add_dtm, sysdate);
		
		// 進捗情報登録
		addPrg(svc_kei_no, getIdoDiv(outMap), sysdate, flg);
		
		//  最終更新年月日時分秒の更新を実施。
		upDateSvkeiExcCtrl(svc_kei_no, sysdate);
	}

	/**
	 * 異動区分取得<br>
	 * <br>
	 * @param outMap 工事完了ワーク又は工事取消ワーク情報。
	 * @return 異動区分値
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private String getIdoDiv(JBSbatCommonDBInterface outMap) throws Exception
	{
		// 工事案件種別コードの取得。
		String kojiak_sbt_cd = JBSbatStringUtil.Rtrim(outMap.getString(JBSbatKK_T_KJ_FIN_WK.KOJIAK_SBT_CD));
		if(super.logPrint.chkLogLevel(JBSbatLogUtil.MODE_DEBUG))
		{
			super.logPrint.printDebugLog("工事案件種別コード:" + kojiak_sbt_cd);
		}
		
		// [006：eo光電話宅内工事]の場合、[00022：光電話・宅内工事設定]を設定。
		if ("006".equals(kojiak_sbt_cd))
		{
			return "00022";
		}
		else 
		{
			// [007：移設]の場合、[00021：移設工事]を設定。
			return "00021";
		}
	}
	
	/**
	 * 
	 * 進捗情報登録。
	 * 
	 * @param svc_kei_no サービス契約番号。
	 * @param ido_div    異動区分。
	 * @param sysdate    システム日付。
	 * @param flg        工事完了ワーク又は工事取消ワーク情報の区別。
	 * @throws Exception メソッド内で発生した例外全般。
	 */
	private void addPrg(String svc_kei_no, String ido_div, String sysdate, boolean flg) throws Exception 
	{
		// 進捗ステータス
		String prg_stat = "";
		
		if (flg)
		{
			prg_stat = "9700";
		}
		else
		{
			prg_stat = "9704";
		}
		// LT-2013-0000025対応
		//共通部品（進捗.異動年月日取得部品）より異動年月日時分秒（またはシステム日付）を取得
		String idoDtm = JKKBatCommon.getIdoDtmMax(commonItem, svc_kei_no, ido_div, stmt);
		
		// 登録する進捗のパラメータを設定します
		String[] setParam = {
				JBSbatStringUtil.padNumFormString(
				JBSbatOracleSeqUtil.getNextSeq(commonItem.getConnection(), SEQ_PRG_NO), 12),	// 進捗番号 → 自動採番
				"",																				// 申込明細番号 →NULL（未設定）
				"",																				// 請求契約番号 → NULL（未設定）
				"",																				// 請求方法番号（口座） → NULL（未設定）
				"",																				// 請求方法番号（クレジットカード） → NULL（未設定）
				svc_kei_no,																		// サービス契約番号 → サービス契約番号
				"",																				// サービス契約内訳番号 → NULL（未設定）
				"",																				// サービス契約回線内訳番号 → NULL（未設定）
				"",																				// 機器提供サービス契約番号 → NULL（未設定）
				"",																				// オプションサービス契約番号 → NULL（未設定）
				"",																				// 請求オプションサービス契約番号 → NULL（未設定）
				"",																				// サブオプションサービス契約番号 → NULL（未設定）
				"",																				// 割引サービス契約番号 → NULL（未設定）
				ido_div,																		// 異動区分 → 異動区分取得メソッドから取得
				idoDtm,																			// 異動年月日時分秒 → 異動年月日時分秒取得共通部品
				prg_stat,																		// 進捗ステータス → 1001
				super.opeDate + sysdate.substring(8),											// 進捗年月日時分秒 → バッチ運用日+実施日のhhmmssSSSを設定。
				"",																				// 進捗メモ → NULL（未設定）
				"",																				// 進捗特記事項１ → NULL（未設定）
				"",																				// 進捗特記事項２ → NULL（未設定）
				sysdate,																		// 登録年月日時分秒 →  システム日時
				batchUserId,		 															// 登録オペレータアカウント → バッチ更新者ＩＤ
				sysdate,																		// 更新年月日時分秒 →  システム日時
				batchUserId,																	// 更新オペレータアカウント → バッチ更新者ＩＤ
				"",																				// 削除年月日時分秒 → NULL（未設定）
				"",																				// 削除オペレータアカウント → NULL（未設定）
				"0",																			// 無効フラグ → "0"(有効)
				"",																				// 登録運用年月日 → NULL（未設定）
				"",																				// 登録処理ID → NULL（未設定）
				"",																				// 更新運用年月日 → NULL（未設定）
				"",																				// 更新処理ID → NULL（未設定）
				"",																				// 削除運用年月日 → NULL（未設定）
				""																				// 削除処理ID → NULL（未設定）
				};
		
		// 進捗登録の実施。
		executeKK_T_PRG_PKINSERT(setParam);
	}
}
