/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatKKSeiOpSvcKeiStaAdd
*	ソースファイル名	：JBSbatKKSeiOpSvcKeiStaAdd.java
*	作成者				：富士通　
*	作成日				：2012年12月21日
*＜機能概要＞
*　請求オプションサービス契約開始登録部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v4.00.00	2012/12/21  FJ)中作		新規作成【ST2-2012-0001934】対応
*	v4.01.00	2013/03/19  FJ)柳		【IT1-2013-0000498】対応
*	v5.00.00	2013/10/25  FJ)中作		【IT1-2013-0000498】対応
*	v6.00.00	2014/1/14   FJ)岡田		【OM-2013-0005306】対応
*	v12.00.00	2015/02/03	FJ)柿坂		【OM-2014-0003966】対応
*	v22.00.00	2015/11/19	FJ)金本		【ANK-2732-00-00】プロジェクト正常化施策 ソースの可読性向上
*********************************************************************/
package eo.business.service;

import java.util.ArrayList;

import eo.business.common.JBSbatBusinessService;
import eo.business.common.JBSbatKKConst;
import eo.business.common.JKKBatCommon;
import eo.business.util.table.JBSbatKK_T_SEIKY_KEI;
import eo.business.util.table.JBSbatKK_T_SEIOPSVC_KEI;
import eo.business.util.table.JBSbatKK_T_SVC_KEI;
import eo.common.constant.JPCBatchMessageConstant;
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.item.JBSbatServiceInterfaceMap;
import eo.framework.util.JBSbatDateUtil;
import eo.framework.util.JBSbatStringUtil;

/**
* (クラスの機能概要) <p>
*<BR>
* @author 富士通
*/
public class JBSbatKKSeiOpSvcKeiStaAdd extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/** テーブル(課金先)*/
	private static final String D_TBL_NAME_KK_T_KAKINS = "KK_T_KAKINS";

	/** テーブル(請求オプションサービス契約)*/
	private static final String D_TBL_NAME_KK_T_SEIOPSVC_KEI = "KK_T_SEIOPSVC_KEI";

	/** テーブル(請求契約)*/
	private static final String D_TBL_NAME_KK_T_SEIKY_KEI = "KK_T_SEIKY_KEI";

	/** SQL定義キー(KK_SELECT_042)*/
	private static final String KK_T_KAKINS_KK_SELECT_042 = "KK_SELECT_042";

/* ++++++++++ v12.00.00 追加開始 ++++++++++ */
	/** SQL定義キー(KK_SELECT_062)*/
	private static final String KK_T_SEIKY_KEI_KK_SELECT_062 = "KK_SELECT_062";
/* ++++++++++ v12.00.00 追加終了 ++++++++++ */

	/** テーブルアクセスクラス(課金先)*/
	private JBSbatSQLAccess db_KK_T_KAKINS = null;

	/** テーブルアクセスクラス(請求オプションサービス契約)*/
	private JBSbatSQLAccess db_KK_T_SEIOPSVC_KEI = null;

	/** テーブルアクセスクラス(請求契約)*/
	private JBSbatSQLAccess db_KK_T_SEIKY_KEI = null;
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/

	/** サービス契約ステータス*/
	/** 優先順位 100 > 210 > 220 > 030*/
	protected String[] strSvcKeiStat = new String[]{"100", "210", "220", "030"};
	
	// ++++++++++ v22.00.00 削除開始 ++++++++++
//	/** サービス契約ステータス(照査済)*/
//	private static String  SVC_KEI_STAT_SHOSA_ZM = "020";
//	
//	/** サービス契約ステータス(締結済)*/
//	private static String  SVC_KEI_STAT_CNC_ZM = "030";
//	
//	/** サービス契約ステータス(サービス提供中)*/
//	private static String  SVC_KEI_STAT_SVC_TK_CHU = "100";
	// ++++++++++ v22.00.00 削除終了 ++++++++++
	
	/** MAX 年月日*/
	private static String  MAX_YMD = "20991231";
	
/* ++++++++++ v12.00.00 追加開始 ++++++++++ */
	/** 業務パラメータＩＤ(KK_FIRST_SEIKY_PRD:初回請求無料期間) */
	private static final String PARAM_ID_KK_FIRST_SEIKY_PRD = "KK_FIRST_SEIKY_PRD";
	
	/** 初回請求無料期間（業務パラメータ設定値）*/
	private String firstSeikyPrd = "";
/* ++++++++++ v12.00.00 追加終了 ++++++++++ */
	
	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);

		// DBアクセスクラスを生成します
		db_KK_T_KAKINS = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KK_T_KAKINS);
		db_KK_T_SEIOPSVC_KEI = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KK_T_SEIOPSVC_KEI);
		db_KK_T_SEIKY_KEI = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KK_T_SEIKY_KEI);
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/
		
/* ++++++++++ v12.00.00 追加開始 ++++++++++ */
		// 業務パラメータより初回請求無料期間取得
		firstSeikyPrd = JKKBatCommon.getWorkParamSetteValue(commonItem, PARAM_ID_KK_FIRST_SEIKY_PRD);
		
		// 業務パラメータより初回請求無料期間が取得できなかった場合
		if (firstSeikyPrd == null)
		{
			throw new JBSbatBusinessException(
					JPCBatchMessageConstant.EKKB0150JE, new String[]{"業務パラメータ管理TBL(KEY:" + PARAM_ID_KK_FIRST_SEIKY_PRD + ")"});
		}
/* ++++++++++ v12.00.00 追加終了 ++++++++++ */
		
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @param inMap　入力電文
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute(JBSbatServiceInterfaceMap inMap) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		
		super.logPrint.printDebugLog("execute_START");
		
		// 予約適用年月日
		String rsvAplyYmd = JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKK_T_SEIOPSVC_KEI.RSV_APLY_YMD));
		
		super.logPrint.printDebugLog("請求オプションサービス契約の予約適用年月日--->" + rsvAplyYmd + "<---");
		super.logPrint.printDebugLog("運用日--------------------------------------->" + opeDate + "<---");
		
		// 予約適用年月日が未来日（予約適用年月日＞運用日）の場合、処理をスキップします。
		// 予約適用年月日が未設定の場合
		if ("".equals(rsvAplyYmd))
		{
			super.logPrint.printDebugLog("予約適用年月日が未設定：スキップ");
			return null;
		}
		
		// 予約適用年月日が運用日より未来日の場合
		if (Integer.parseInt(rsvAplyYmd) > Integer.parseInt(opeDate))
		{
			super.logPrint.printDebugLog("予約適用年月日が運用日より未来日の場合：スキップ");
			return null;
		}
		
		// 請求契約番号
		String seikyKeiNo = JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKK_T_SEIOPSVC_KEI.SEIKY_KEI_NO));
		
		super.logPrint.printDebugLog("請求オプションサービス契約の請求契約番号--->" + seikyKeiNo + "<---");
		super.logPrint.printDebugLog("請求オプションサービス契約の請求オプションサービス契約ステータス--->" + JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKK_T_SEIOPSVC_KEI.SEIOPSVC_KEI_STAT)) + "<---");
		
		// 対象サービス契約取得
		ArrayList<JBSbatCommonDBInterface> svcKeiInfoList = searchSvcKeiInfo(seikyKeiNo);
		
		super.logPrint.printDebugLog("対象サービス契約取得--->" + svcKeiInfoList.size() + "件<---");
		
		// 対象サービス契約取得なし
		if(0 == svcKeiInfoList.size())
		{
			super.logPrint.printDebugLog("対象サービス契約なし");
			return null;
		}
		
		// サービス契約のサービス契約ステータス判定
		String svcKeiStat = getSvcKeiStat(svcKeiInfoList);
		
		super.logPrint.printDebugLog("サービス契約のサービス契約ステータス--->" + svcKeiStat + "<---");
		
		// 請求オプションサービス契約ステータス
		String seiopsvcKeiStat = JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKK_T_SEIOPSVC_KEI.SEIOPSVC_KEI_STAT));
		
		// "締結済"の場合
		// ++++++++++ v22.00.00 変更開始 ++++++++++
//		if(SVC_KEI_STAT_CNC_ZM.equals(svcKeiStat) && SVC_KEI_STAT_CNC_ZM.equals(seiopsvcKeiStat))
		if(JBSbatKKConst.SVC_KEI_STAT_CNC_ZM .equals(svcKeiStat) && JBSbatKKConst.SVC_KEI_STAT_CNC_ZM .equals(seiopsvcKeiStat))
		// ++++++++++ v22.00.00 変更終了 ++++++++++
		{
			return null;
		}
		
		// 請求オプションサービス登録
		createSeiopsvcKei(inMap, svcKeiStat);
		
		super.logPrint.printDebugLog("execute_END");
		
		return null;
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		// DBアクセスクラスをクローズします
		db_KK_T_KAKINS.close();
		db_KK_T_SEIOPSVC_KEI.close();
		db_KK_T_SEIKY_KEI.close();
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	/**
	 * SQLKEY(KK_SELECT_042)で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_KAKINS_KK_SELECT_042(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());
		paramList.setValue(param[1].toString());
		paramList.setValue(param[2].toString());

		// DBアクセスを実行します
		db_KK_T_KAKINS.selectBySqlDefine(paramList, KK_T_KAKINS_KK_SELECT_042);
	}

	/**
	 * PK(全項目登録)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数で設定項目マップを作ります。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		setParam:設定したい項目の(項目、値)を(key、value)として、setParamマップに入れます。項目キーは以下に説明します。
	 *		 	請求オプションサービス契約番号				SEIOPSVC_KEI_NO
	 *		 	世代登録年月日時分秒				GENE_ADD_DTM
	 *		 	請求オプションサービス契約ステータス				SEIOPSVC_KEI_STAT
	 *		 	請求契約番号				SEIKY_KEI_NO
	 *		 	ＳＹＳＩＤ				SYSID
	 *		 	請求オプションサービスコード				SEIOPSVC_CD
	 *		 	料金コースコード				PCRS_CD
	 *		 	料金プランコード				PPLAN_CD
	 *		 	申込明細番号				MSKM_DTL_NO
	 *		 	サービス契約番号				SVC_KEI_NO
	 *		 	試用加入年月日				FTRIAL_KANYU_YMD
	 *		 	試用期間終了年月日				FTRIAL_PRD_ENDYMD
	 *		 	本加入年月日				HONKANYU_YMD
	 *		 	本加入移行期限年月日				HONKANYU_IKO_KIGEN_YMD
	 *		 	サービス利用開始希望年月日				SVC_USE_STA_KIBO_YMD
	 *		 	予約適用開始希望年月日				RSV_TSTA_KIBO_YMD
	 *		 	請求オプションサービス契約後続業務依頼年月日				SEIOPSVC_KEI_KZKWRK_REQYMD
	 *		 	照査年月日				SHOSA_YMD
	 *		 	照査取消年月日				SHOSA_CL_YMD
	 *		 	審査結果送信コード				SKEKKA_SEND_CD
	 *		 	契約締結年月日				KEI_CNC_YMD
	 *		 	予約適用年月日				RSV_APLY_YMD
	 *		 	予約取消年月日				RSV_CL_YMD
	 *		 	予約適用コード				RSV_APLY_CD
	 *		 	プラン開始年月日				PLAN_STAYMD
	 *		 	プラン終了年月日				PLAN_ENDYMD
	 *		 	プラン課金開始年月日				PLAN_CHRG_STAYMD
	 *		 	プラン課金終了年月日				PLAN_CHRG_ENDYMD
	 *		 	プラン終了種別コード				PLAN_END_SBT_CD
	 *		 	サービスキャンセル年月日				SVC_CANCEL_YMD
	 *		 	サービスキャンセル理由コード				SVC_CANCEL_RSN_CD
	 *		 	サービス開始年月日				SVC_STA_YMD
	 *		 	サービス課金開始年月日				SVC_CHRG_STAYMD
	 *		 	サービス停止年月日				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_YMD
	 *		 	サービス解約理由コード				SVC_DLRE_CD
	 *		 	サービス解約理由メモ				SVC_DLRE_MEMO
	 *		 	サービス解約手続完了フラグ				SVC_DSL_TTDKI_FIN_FLG
	 *		 	回復年月日				KAIHK_YMD
	 *		 	サービスキャンセル取消年月日				SVC_CANCEL_CL_YMD
	 *		 	サービス解約取消年月日				SVC_DSL_CL_YMD
	 *		 	課金開始年月日補正有無				CHRG_STA_YMD_HOSEI_UM
	 *		 	サービス休止課金開始年月日				SVC_PAUSE_CHRG_STA_YMD
	 *		 	違約金発生コード				PNLTY_HASSEI_CD
	 *		 	異動区分				IDO_DIV
	 *		 	照査解約完了コード				SHOSA_DSL_FIN_CD
	 *		 	登録年月日時分秒				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_SEIOPSVC_KEI_PKINSERT(Object[] setParam) throws Exception
	{
		// 設定値のマップを作成します
		JBSbatCommonDBInterface setMap = new JBSbatCommonDBInterface();
		setMap.setValue("SEIOPSVC_KEI_NO", setParam[0]);
		setMap.setValue("GENE_ADD_DTM", setParam[1]);
		setMap.setValue("SEIOPSVC_KEI_STAT", setParam[2]);
		setMap.setValue("SEIKY_KEI_NO", setParam[3]);
		setMap.setValue("SYSID", setParam[4]);
		setMap.setValue("SEIOPSVC_CD", setParam[5]);
		setMap.setValue("PCRS_CD", setParam[6]);
		setMap.setValue("PPLAN_CD", setParam[7]);
		setMap.setValue("MSKM_DTL_NO", setParam[8]);
		setMap.setValue("SVC_KEI_NO", setParam[9]);
		setMap.setValue("FTRIAL_KANYU_YMD", setParam[10]);
		setMap.setValue("FTRIAL_PRD_ENDYMD", setParam[11]);
		setMap.setValue("HONKANYU_YMD", setParam[12]);
		setMap.setValue("HONKANYU_IKO_KIGEN_YMD", setParam[13]);
		setMap.setValue("SVC_USE_STA_KIBO_YMD", setParam[14]);
		setMap.setValue("RSV_TSTA_KIBO_YMD", setParam[15]);
		setMap.setValue("SEIOPSVC_KEI_KZKWRK_REQYMD", setParam[16]);
		setMap.setValue("SHOSA_YMD", setParam[17]);
		setMap.setValue("SHOSA_CL_YMD", setParam[18]);
		setMap.setValue("SKEKKA_SEND_CD", setParam[19]);
		setMap.setValue("KEI_CNC_YMD", setParam[20]);
		setMap.setValue("RSV_APLY_YMD", setParam[21]);
		setMap.setValue("RSV_CL_YMD", setParam[22]);
		setMap.setValue("RSV_APLY_CD", setParam[23]);
		setMap.setValue("PLAN_STAYMD", setParam[24]);
		setMap.setValue("PLAN_ENDYMD", setParam[25]);
		setMap.setValue("PLAN_CHRG_STAYMD", setParam[26]);
		setMap.setValue("PLAN_CHRG_ENDYMD", setParam[27]);
		setMap.setValue("PLAN_END_SBT_CD", setParam[28]);
		setMap.setValue("SVC_CANCEL_YMD", setParam[29]);
		setMap.setValue("SVC_CANCEL_RSN_CD", setParam[30]);
		setMap.setValue("SVC_STA_YMD", setParam[31]);
		setMap.setValue("SVC_CHRG_STAYMD", setParam[32]);
		setMap.setValue("SVC_STP_YMD", setParam[33]);
		setMap.setValue("SVC_STP_RSN_CD", setParam[34]);
		setMap.setValue("SVC_STP_RLS_YMD", setParam[35]);
		setMap.setValue("SVC_STP_RLS_RSN_CD", setParam[36]);
		setMap.setValue("PAUSE_STP_CD", setParam[37]);
		setMap.setValue("SVC_PAUSE_YMD", setParam[38]);
		setMap.setValue("SVC_PAUSE_RSN_CD", setParam[39]);
		setMap.setValue("SVC_PAUSE_RSN_MEMO", setParam[40]);
		setMap.setValue("SVC_PAUSE_RLS_YMD", setParam[41]);
		setMap.setValue("SVC_PAUSE_RLS_RSN_CD", setParam[42]);
		setMap.setValue("SVC_PAUSE_RLS_RSN_MEMO", setParam[43]);
		setMap.setValue("SVC_ENDYMD", setParam[44]);
		setMap.setValue("SVC_CHRG_ENDYMD", setParam[45]);
		setMap.setValue("SVC_DSL_YMD", setParam[46]);
		setMap.setValue("SVC_DLRE_CD", setParam[47]);
		setMap.setValue("SVC_DLRE_MEMO", setParam[48]);
		setMap.setValue("SVC_DSL_TTDKI_FIN_FLG", setParam[49]);
		setMap.setValue("KAIHK_YMD", setParam[50]);
		setMap.setValue("SVC_CANCEL_CL_YMD", setParam[51]);
		setMap.setValue("SVC_DSL_CL_YMD", setParam[52]);
		setMap.setValue("CHRG_STA_YMD_HOSEI_UM", setParam[53]);
		setMap.setValue("SVC_PAUSE_CHRG_STA_YMD", setParam[54]);
		setMap.setValue("PNLTY_HASSEI_CD", setParam[55]);
		setMap.setValue("IDO_DIV", setParam[56]);
		setMap.setValue("SHOSA_DSL_FIN_CD", setParam[57]);
		setMap.setValue("ADD_DTM", setParam[58]);
		setMap.setValue("ADD_OPEACNT", setParam[59]);
		setMap.setValue("UPD_DTM", setParam[60]);
		setMap.setValue("UPD_OPEACNT", setParam[61]);
		setMap.setValue("DEL_DTM", setParam[62]);
		setMap.setValue("DEL_OPEACNT", setParam[63]);
		setMap.setValue("MK_FLG", setParam[64]);
		setMap.setValue("ADD_UNYO_YMD", setParam[65]);
		setMap.setValue("ADD_TRN_ID", setParam[66]);
		setMap.setValue("UPD_UNYO_YMD", setParam[67]);
		setMap.setValue("UPD_TRN_ID", setParam[68]);
		setMap.setValue("DEL_UNYO_YMD", setParam[69]);
		setMap.setValue("DEL_TRN_ID", setParam[70]);
	
		// DBアクセスを実行します
		db_KK_T_SEIOPSVC_KEI.insertByPrimaryKeys(setMap);
	}
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/
	
	
	
	/**
	 * 対象のサービス契約取得
	 * @param seikyKeiNo 請求契約番号
	 * @return ArrayList サービス契約情報
	 * @throws Exception 
	 */
	private ArrayList<JBSbatCommonDBInterface> searchSvcKeiInfo(String seikyKeiNo) throws Exception
	{
		ArrayList<JBSbatCommonDBInterface> resultList = new ArrayList<JBSbatCommonDBInterface>();
		
		executeKK_T_KAKINS_KK_SELECT_042(new Object[]{opeDate, seikyKeiNo, opeDate});
		
		JBSbatCommonDBInterface dbInfo = db_KK_T_KAKINS.selectNext();
		
		while(null != dbInfo)
		{
			resultList.add(dbInfo);
			
			// 次の検索処理を取得
			dbInfo = db_KK_T_KAKINS.selectNext();
		}
		
		return resultList;
	}
	
	/**
	 * サービス契約ステータスを取得します
	 * @param svcKeiInfoList サービス契約情報
	 * @return String
	 * @throws Exception 
	 */
	private String getSvcKeiStat(ArrayList<JBSbatCommonDBInterface> svcKeiInfoList) throws Exception
	{
		String result = "";
		
		for(int i = 0; i < strSvcKeiStat.length; i++)
		{
			result = strSvcKeiStat[i];
			
			for(int j = 0; j < svcKeiInfoList.size(); j++)
			{
				JBSbatCommonDBInterface dbInfo = svcKeiInfoList.get(j);
				
				// サービス契約ステータス
				String svcKeiStat = JBSbatStringUtil.Rtrim(dbInfo.getString(JBSbatKK_T_SVC_KEI.SVC_KEI_STAT));
				
				if(result.equals(svcKeiStat))
				{
					return result;
				}
			}
		}
		
		return result;
	}
	
	/**
	 * ステータスにより請求オプションサービス契約の登録を行います
	 * @param inMap 請求オプションサービス契約
	 * @param svcKeiStat サービス契約のステータス
	 * @throws Exception 
	 */
	private void createSeiopsvcKei(JBSbatServiceInterfaceMap inMap, String svcKeiStat) throws Exception
	{
		// システム日付
		String sysDate = JBSbatDateUtil.getSystemDateTimeStamp();
		
		// 請求オプションサービス契約ステータス
		String seiopsvcKeiStat = JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKK_T_SEIOPSVC_KEI.SEIOPSVC_KEI_STAT));
		
		// 請求オプションサービス契約番号
		String seiopsvcKeiNo = JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKK_T_SEIOPSVC_KEI.SEIOPSVC_KEI_NO));
		
		// 世代年月日時分秒
		String geneAddDtm = JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKK_T_SEIOPSVC_KEI.GENE_ADD_DTM));
		
		// 請求オプションサービス契約テーブルに排他制御処理を実行する
		JBSbatCommonDBInterface whereMap = new JBSbatCommonDBInterface();
		whereMap.setValue(JBSbatKK_T_SEIOPSVC_KEI.SEIOPSVC_KEI_NO, seiopsvcKeiNo);
		whereMap.setValue(JBSbatKK_T_SEIOPSVC_KEI.GENE_ADD_DTM, geneAddDtm);
		
		JBSbatCommonDBInterface dbmap = db_KK_T_SEIOPSVC_KEI.selectByPrimaryKeysForUpdateWait(whereMap);
		
		// 排他失敗の場合エラーとします。
		if (null == dbmap)
		{
			throw new JBSbatBusinessException("EKKB0360KE", new String[]{"請求オプションサービス契約TBL", seiopsvcKeiNo});
		}
		
		// サービス契約ステータス
		// 締結済
		// ++++++++++ v22.00.00 変更開始 ++++++++++
//		if(SVC_KEI_STAT_CNC_ZM.equals(svcKeiStat))
		if(JBSbatKKConst.SVC_KEI_STAT_CNC_ZM .equals(svcKeiStat))
		// ++++++++++ v22.00.00 変更終了 ++++++++++
		{
			// 請求オプションサービス契約
			// 照査済
			// ++++++++++ v22.00.00 変更開始 ++++++++++
//			if(SVC_KEI_STAT_SHOSA_ZM.equals(seiopsvcKeiStat))
			if(JBSbatKKConst.SVC_KEI_STAT_SHOSA_ZM.equals(seiopsvcKeiStat))
			// ++++++++++ v22.00.00 変更終了 ++++++++++
			{
				// "020:照査済"→"030:締結済"
				insertSeiopsvcKei(inMap, sysDate, "1");
			}
		}
		// サービス提供中,休止・中断中,停止中
		else
		{
			// 請求オプションサービス契約
			// 照査済
			// ++++++++++ v22.00.00 変更開始 ++++++++++
//			if(SVC_KEI_STAT_SHOSA_ZM.equals(seiopsvcKeiStat))
			if(JBSbatKKConst.SVC_KEI_STAT_SHOSA_ZM.equals(seiopsvcKeiStat))
			// ++++++++++ v22.00.00 変更終了 ++++++++++
			{
				// "020:照査済"→"030:締結済"
				insertSeiopsvcKei(inMap, sysDate, "1");
				
				// "030:締結済"→"100:サービス提供中"
				insertSeiopsvcKei(inMap, sysDate, "3");
				
			}
			// 請求オプションサービス契約
			// 締結済
			// ++++++++++ v22.00.00 変更開始 ++++++++++
//			else if(SVC_KEI_STAT_CNC_ZM.equals(seiopsvcKeiStat))
			else if(JBSbatKKConst.SVC_KEI_STAT_CNC_ZM .equals(seiopsvcKeiStat))
			// ++++++++++ v22.00.00 変更終了 ++++++++++
			{
				// "030:締結済"→"100:サービス提供中"
				insertSeiopsvcKei(inMap, sysDate, "2");
				
			}
		}
	}

	/**
	 * 請求オプションサービス契約を登録します。
	 * <br>
	 * @param inMap 請求オプションサービス契約検索結果
	 * @param sysDate システム日付
	 * @param flg 登録パターン "1":020→030
	 *                          "2":030→100
	 *                          "3":020→030 030→100
	 * @throws Exception 
	 */
	private void insertSeiopsvcKei(JBSbatServiceInterfaceMap inMap, String sysDatePara, String flg) throws Exception
	{
		// 世代登録年月日時分秒
		String geneAddDtm = "";
		
		// 請求オプションサービス契約ステータス
		String seiopsvcKeiStat = "";
		
		// 契約締結年月日
		String keiCncYmd = "";
		
		// サービス開始年月日
		String svcStaYmd = "";
		
		// サービス課金開始年月日
		String svcChrgStaymd = "";
		
		// サービス終了年月日
		String svcEndymd = "";
		
		// サービス課金終了年月日
		String svcChrgEndymd = "";
		
		// プラン開始年月日
		String planStaymd = "";
		
		// プラン終了年月日
		String planEndymd = "";
		
		// プラン課金開始年月日
		String planChrgStaymd = "";
		
		// プラン課金終了年月日
		String planChrgEndymd = "";
		
		// システム日付を取得
		// 登録パターン"3"の登録用
		String sysdate = JBSbatDateUtil.getSystemDateTimeStamp();
		
		// 請求オプションサービス契約番号
		String seiopsvcKeiNo = JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKK_T_SEIOPSVC_KEI.SEIOPSVC_KEI_NO));
		
		// 登録パターン
		if("3".equals(flg))
		{
			// 世代登録年月日時分秒
			geneAddDtm = sysDatePara;
		}
		else
		{
			// 世代登録年月日時分秒
			geneAddDtm = JBSbatStringUtil.Rtrim(inMap.getString(JBSbatKK_T_SEIOPSVC_KEI.GENE_ADD_DTM));
		}
		
		// 請求オプションサービス契約PK検索を実行する
		JBSbatCommonDBInterface whereMap = new JBSbatCommonDBInterface();
		
		// 請求契約番号
		whereMap.setValue(JBSbatKK_T_SEIOPSVC_KEI.SEIOPSVC_KEI_NO, seiopsvcKeiNo);
		
		// 世代登録年月日時分秒
		whereMap.setValue(JBSbatKK_T_SEIOPSVC_KEI.GENE_ADD_DTM, geneAddDtm);
		
		// PK検索
		JBSbatCommonDBInterface dbInfoSeiOpSvcKei = db_KK_T_SEIOPSVC_KEI.selectByPrimaryKeys(whereMap);
		
		// 登録パターン1
		if("1".equals(flg))
		{
			// 請求オプションサービス契約ステータス
			// "030:締結済"
			// ++++++++++ v22.00.00 変更開始 ++++++++++
//			seiopsvcKeiStat = SVC_KEI_STAT_CNC_ZM;;
			seiopsvcKeiStat = JBSbatKKConst.SVC_KEI_STAT_CNC_ZM ;
			// ++++++++++ v22.00.00 変更終了 ++++++++++
			
			// 契約締結年月日
			// 運用日
			keiCncYmd = opeDate;
			
			// サービス開始年月日
			svcStaYmd = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_STA_YMD));
			
			// サービス課金開始年月日
			svcChrgStaymd = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_CHRG_STAYMD));
			
			// サービス終了年月日
			svcEndymd = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_ENDYMD));
			
			// サービス課金終了年月日
			svcChrgEndymd = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_CHRG_ENDYMD));
			
			// プラン開始年月日
			planStaymd = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.PLAN_STAYMD));
			
			// プラン終了年月日
			planEndymd = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.PLAN_ENDYMD));
			
			// プラン課金開始年月日
			planChrgStaymd = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.PLAN_CHRG_STAYMD));
			
			// プラン課金終了年月日
			planChrgEndymd = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.PLAN_CHRG_ENDYMD));
		}
		// 登録パターン2,3
		else
		{
			// 請求オプションサービス契約ステータス
			// "100:サービス提供中"
			// ++++++++++ v22.00.00 変更開始 ++++++++++
//			seiopsvcKeiStat = SVC_KEI_STAT_SVC_TK_CHU;
			seiopsvcKeiStat = JBSbatKKConst.SVC_KEI_STAT_SVCTK_CHU;
			// ++++++++++ v22.00.00 変更終了 ++++++++++
			
			// 契約締結年月日
			keiCncYmd = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.KEI_CNC_YMD));
			
			// サービス開始年月日
			// 運用日
			svcStaYmd = opeDate;
			
/* ++++++++++ v12.00.00 修正開始 ++++++++++ */
//			// サービス課金開始年月日
//			// 運用日の翌月月初
//			svcChrgStaymd = JBSbatDateUtil.adjustMonth(opeDate, 1).substring(0, 6) + "01";
//			super.logPrint.printDebugLog("サービス課金開始年月日★★★" + svcChrgStaymd);
			
			// 請求書発行手数料のみ初回請求年月の無料期間判定を行う
			// ++++++++++ v22.00.00 変更開始 ++++++++++
//			if("E001".equals(JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SEIOPSVC_CD))))
			if(JBSbatKKConst.CD00131_SEIOPSVC_CD_E001.equals(JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SEIOPSVC_CD))))
			// ++++++++++ v22.00.00 変更終了 ++++++++++
			{
				
				// 請求契約番号
				executeKK_T_SEIKY_KEI_KK_SELECT_062(
						new Object[]{
								JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SEIKY_KEI_NO)),
								opeDate
						});
				
				JBSbatCommonDBInterface dbInfo = db_KK_T_SEIKY_KEI.selectNext();
				
				String seikyYm = "";
				while(null != dbInfo)
				{
					// 請求契約．初回請求年月を取得
					seikyYm = JBSbatStringUtil.Rtrim(dbInfo.getString(JBSbatKK_T_SEIKY_KEI.FIRST_SEIKY_YM));
					break;
				}
				
				// 初回請求年月が未設定の場合、運用日の翌月月初を設定する
				if("".equals(seikyYm))
				{
					// サービス課金開始年月日
					// 運用日の翌月月初
					svcChrgStaymd = JBSbatDateUtil.adjustMonth(opeDate, 1).substring(0, 6) + "01";
				} 
				else 
				{
					// 請求年月情報ファイル.請求年月の+(初回請求無料期間+1)の月初め
					int add = Integer.parseInt(firstSeikyPrd) + 1;
					svcChrgStaymd = JBSbatDateUtil.adjustMonth(seikyYm + "01", add);
					
					String svcChrgStaym = svcChrgStaymd.substring(0,6);
					String svcStaYm = svcStaYmd.substring(0,6);
					// サービス開始年月がサービス課金開始年月より同月または未来の場合はサービス開始日の翌月月初をサービス課金開始日に設定
					if(svcStaYm.compareTo(svcChrgStaym) >=0){
						
						svcChrgStaymd = JBSbatDateUtil.adjustMonth(svcStaYm + "01", 1);
					}
				}
			}
			else 
			{
				// サービス課金開始年月日
				// 運用日の翌月月初
				svcChrgStaymd = JBSbatDateUtil.adjustMonth(opeDate, 1).substring(0, 6) + "01";
			}
			super.logPrint.printDebugLog("サービス課金開始年月日★★★" + svcChrgStaymd);
/* ++++++++++ v12.00.00 修正終了 ++++++++++ */
			
			// サービス終了年月日
			// "20991231"
			svcEndymd = MAX_YMD;
			
			// サービス課金終了年月日
			// "20991231"
			svcChrgEndymd = MAX_YMD;
			
			// プラン開始年月日
			// 運用日
			planStaymd = opeDate;
			
			// プラン終了年月日
			// "20991231"
			planEndymd = MAX_YMD;
			
/* ++++++++++ v12.00.00 修正開始 ++++++++++ */
//			// プラン課金開始年月日
//			// 運用日の翌月月初
//			planChrgStaymd = JBSbatDateUtil.adjustMonth(opeDate, 1).substring(0, 6) + "01";
			
			// プラン課金開始年月日
			// サービス課金開始年月日と同じ日付を設定
			planChrgStaymd = svcChrgStaymd;
/* ++++++++++ v12.00.00 修正終了 ++++++++++ */
			super.logPrint.printDebugLog("プラン課金開始年月日★★★" + planChrgStaymd);
			
			// プラン課金終了年月日
			planChrgEndymd = MAX_YMD;
		}
		
		// 登録用データ格納
		Object[] setParam = new Object[71];
		
		// 請求オプションサービス契約番号
		setParam[0] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SEIOPSVC_KEI_NO));
		
		// 登録パターン
		if("3".equals(flg))
		{
			// 世代登録年月日時分秒
			// システム日付
			setParam[1] = sysdate;
		}
		else
		{
			setParam[1] = sysDatePara;
		}
		
		// 請求オプションサービス契約ステータス
		setParam[2] = seiopsvcKeiStat;
		
		// 請求契約番号
		setParam[3] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SEIKY_KEI_NO));
		
		// ＳＹＳＩＤ
		setParam[4] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SYSID));
		
		// 請求オプションサービスコード
		setParam[5] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SEIOPSVC_CD));
		
		// 料金コースコード
		setParam[6] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.PCRS_CD));
		
		// 料金プランコード
		setParam[7] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.PPLAN_CD));
		
		// 申込明細番号
		setParam[8] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.MSKM_DTL_NO));
		
		// サービス契約番号
		setParam[9] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_KEI_NO));
		
		// 試用加入年月日
		setParam[10] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.FTRIAL_KANYU_YMD));
		
		// 試用期間終了年月日
		setParam[11] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.FTRIAL_PRD_ENDYMD));
		
		// 本加入年月日
		setParam[12] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.HONKANYU_YMD));
		
		// 本加入移行期限年月日
		setParam[13] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.HONKANYU_IKO_KIGEN_YMD));
		
		// サービス利用開始希望年月日
		setParam[14] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_USE_STA_KIBO_YMD));
		
		// 予約適用開始希望年月日
		setParam[15] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.RSV_TSTA_KIBO_YMD));
		
		// 請求オプションサービス契約後続業務依頼年月日
		setParam[16] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SEIOPSVC_KEI_KZKWRK_REQYMD));
		
		// 照査年月日
		setParam[17] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SHOSA_YMD));
		
		// 照査取消年月日
		setParam[18] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SHOSA_CL_YMD));
		
		// 審査結果送信コード
		setParam[19] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SKEKKA_SEND_CD));
		
		// 契約締結年月日
		setParam[20] = keiCncYmd;
		
		// 予約適用年月日
		setParam[21] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.RSV_APLY_YMD));
		
		// 予約取消年月日
		setParam[22] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.RSV_CL_YMD));
		
		// 予約適用コード
		setParam[23] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.RSV_APLY_CD));
		
		// プラン開始年月日
		setParam[24] = planStaymd;
		
		// プラン終了年月日
		setParam[25] = planEndymd;
		
		// プラン課金開始年月日
		setParam[26] = planChrgStaymd;
		
		// プラン課金終了年月日
		setParam[27] = planChrgEndymd;
		
		// プラン終了種別コード
		setParam[28] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.PLAN_END_SBT_CD));
		
		// サービスキャンセル年月日
		setParam[29] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_CANCEL_YMD));
		
		// サービスキャンセル理由コード
		setParam[30] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_CANCEL_RSN_CD));
		
		// サービス開始年月日
		setParam[31] = svcStaYmd;
		
		// サービス課金開始年月日
		setParam[32] = svcChrgStaymd;
		
		// サービス停止年月日
		setParam[33] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_STP_YMD));
		
		// サービス停止理由コード
		setParam[34] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_STP_RSN_CD));
		
		// サービス停止解除年月日
		setParam[35] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_STP_RLS_YMD));
		
		// サービス停止解除理由コード
		setParam[36] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_STP_RLS_RSN_CD));
		
		// 休止中断コード
		setParam[37] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.PAUSE_STP_CD));
		
		// サービス休止年月日
		setParam[38] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_PAUSE_YMD));
		
		// サービス休止理由コード
		setParam[39] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_PAUSE_RSN_CD));
		
		// サービス休止理由メモ
		setParam[40] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_PAUSE_RSN_MEMO));
		
		// サービス休止解除年月日
		setParam[41] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_PAUSE_RLS_YMD));
		
		// サービス休止解除理由コード
		setParam[42] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_PAUSE_RLS_RSN_CD));
		
		// サービス休止解除理由メモ
		setParam[43] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_PAUSE_RLS_RSN_MEMO));
		
		// サービス終了年月日
		setParam[44] = svcEndymd;
		
		// サービス課金終了年月日
		setParam[45] = svcChrgEndymd;
		
		// サービス解約年月日
		setParam[46] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_DSL_YMD));
		
		// サービス解約理由コード
		setParam[47] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_DLRE_CD));
		
		// サービス解約理由メモ
		setParam[48] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_DLRE_MEMO));
		
		// サービス解約手続完了フラグ
		setParam[49] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_DSL_TTDKI_FIN_FLG));
		
		// 回復年月日
		setParam[50] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.KAIHK_YMD));
		
		// サービスキャンセル取消年月日
		setParam[51] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_CANCEL_CL_YMD));
		
		// サービス解約取消年月日
		setParam[52] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_DSL_CL_YMD));
		
		// 課金開始年月日補正有無
		setParam[53] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.CHRG_STA_YMD_HOSEI_UM));
		
		// サービス休止課金開始年月日
		setParam[54] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SVC_PAUSE_CHRG_STA_YMD));
		
		// 違約金発生コード
		setParam[55] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.PNLTY_HASSEI_CD));
		
		// 異動区分
		setParam[56] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.IDO_DIV));
		
		// 照査解約完了コード
		setParam[57] = JBSbatStringUtil.Rtrim(dbInfoSeiOpSvcKei.getString(JBSbatKK_T_SEIOPSVC_KEI.SHOSA_DSL_FIN_CD));
		
		// 登録年月日時分秒
		setParam[58] = sysDatePara;
		
		// 登録オペレータアカウント
		setParam[59] = super.batchUserId;
		
		// 更新年月日時分秒
		setParam[60] = sysDatePara;
		
		// 更新オペレータアカウント
		setParam[61] = super.batchUserId;
		
		// 削除年月日時分秒設定
		setParam[62] = "";
		
		// 削除オペレータアカウント
		setParam[63] = "";
		
		// 無効フラグ
		// ++++++++++ v22.00.00 変更開始 ++++++++++
//		setParam[64] = "0";
		setParam[64] = JBSbatKKConst.MK_FLG_YK;
		// ++++++++++ v22.00.00 変更終了 ++++++++++
		
		// 登録運用年月日
		setParam[65] = "";
		
		// 登録処理ＩＤ
		setParam[66] = "";
		
		// 更新運用年月日
		setParam[67] = "";
		
		// 更新処理ＩＤ
		setParam[68] = "";
		
		// 削除運用年月日
		setParam[69] = "";
		
		// 削除処理ＩＤ
		setParam[70] = "";
		
		executeKK_T_SEIOPSVC_KEI_PKINSERT(setParam);
	}
	
/* ++++++++++ v12.00.00 追加開始 ++++++++++ */
	/**
	 * SQLKEY(KK_SELECT_062)で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_SEIKY_KEI_KK_SELECT_062(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());
		paramList.setValue(param[1].toString());

		// DBアクセスを実行します
		db_KK_T_SEIKY_KEI.selectBySqlDefine(paramList, KK_T_SEIKY_KEI_KK_SELECT_062);
	}
/* ++++++++++ v12.00.00 追加終了 ++++++++++ */
}
