/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatKUDslInfoHjHanei
*	ソースファイル名	：JBSbatKUDslInfoHjHanei.java
*	作成者				：富士通　
*	作成日				：2011年10月24日
*＜機能概要＞
*　解約情報反映（法人）部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/10/24   富士通		新規作成
*********************************************************************/
package eo.business.service;

import java.util.HashMap;

import eo.business.common.JBSbatBusinessService;
import eo.business.common.JKUBatCommon;
import eo.business.util.file.JBSbatKUIFE044;
import eo.business.util.table.JBSbatKU_T_HOJINSVKEI_KJAK;
import eo.business.util.table.JBSbatKU_T_KOJIAK;
import eo.common.constant.JKUStrConst;
import eo.common.constant.JPCBatchMessageConstant;
import eo.common.constant.JZM0171Constant;
import eo.framework.item.JBSbatCommonItem;
import eo.framework.item.JBSbatServiceInterfaceMap;
import eo.framework.item.JBSbatOutputItem;
import eo.framework.item.JBSbatCommonDBInterface;
import eo.framework.application.JBSbatBusinessError;
import eo.framework.db.JBSbatSQLAccess;
import eo.framework.util.JBSbatCheckUtil;

/**
* 解約情報反映（法人）部品 <p>
*<BR>
* @author 富士通
*/
public class JBSbatKUDslInfoHjHanei extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/** テーブル(法人サービス契約＿工事案件ＰＫ更新)*/
	private static final String D_TBL_NAME_KU_T_HOJINSVKEI_KJAK = "KU_T_HOJINSVKEI_KJAK";

	/** テーブル(工事案件ＰＫ更新)*/
	private static final String D_TBL_NAME_KU_T_KOJIAK = "KU_T_KOJIAK";

	/** SQL定義キー(KU_SELECT_001)*/
	private static final String KU_T_HOJINSVKEI_KJAK_KU_SELECT_001 = "KU_SELECT_001";

	/** テーブルアクセスクラス(法人サービス契約＿工事案件ＰＫ更新)*/
	private JBSbatSQLAccess db_KU_T_HOJINSVKEI_KJAK = null;

	/** テーブルアクセスクラス(工事案件ＰＫ更新)*/
	private JBSbatSQLAccess db_KU_T_KOJIAK = null;
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/
	/**▼▼▼▼▼▼業務チームで作成した宣言です 開始▲▲▲▲▲▲*/
	
	/** テーブル(コード名称管理)*/
	private static final String D_TBL_NAME_ZM_M_CD_NM_KANRI = "ZM_M_CD_NM_KANRI";
	
	/** テーブルアクセスクラス(コード名称管理)*/
	private JBSbatSQLAccess db_ZM_M_CD_NM_KANRI = null;
	
	/** ログ出力用項目名設定Map*/
	private HashMap<String, String> messageMap = null;
	/**▲▲▲▲▲▲業務チームで作成した宣言です 終了▲▲▲▲▲▲*/

	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);

		// DBアクセスクラスを生成します
		db_KU_T_HOJINSVKEI_KJAK = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KU_T_HOJINSVKEI_KJAK);
		db_KU_T_KOJIAK = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KU_T_KOJIAK);
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/
		
		db_ZM_M_CD_NM_KANRI = new JBSbatSQLAccess(commonItem, D_TBL_NAME_ZM_M_CD_NM_KANRI);
		
		// ログ出力用項目名設定Mapを設定
		messageMap = createMessageMap();

	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @param inMap　入力電文
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute(JBSbatServiceInterfaceMap inMap) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		// 入力レコードの項目数チェック 
		if(inMap.isInputErrorFlg()) 
		{
			// エラーログを出力し続行する。
			super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.EKUB0490CE, new String[]{});
			
			throw new JBSbatBusinessError();
		}
		
		// 単項目チェック
		if (!this.isSingleCheckKUIFE044_INF1_Mdf(inMap.getMap(), messageMap))
		{
			throw new JBSbatBusinessError();
		}
		
		// コード名称定義マスタチェック
		if (!this.isCodeCheck(inMap.getMap(), messageMap))
		{
			throw new JBSbatBusinessError();
		}
		
		// サービス契約番号
		String svcKeiNo = inMap.getString(JBSbatKUIFE044.SVC_KEI_NO);

		// 工事案件番号
		String kojiakNo = null;

		// 工事案件Map
		JBSbatCommonDBInterface ku0011Map = null;
		
		// 法人サービス契約＿工事案件検索(取得結果の一件目のみ処理する)
		JBSbatCommonDBInterface ku0071Select001Map = this.findKU_T_HOJINSVKEI_KJAK_KU_SELECT_001(svcKeiNo);
		
		// 法人サービス契約＿工事案件が存在しない場合、次レコードへ
		if (!JKUBatCommon.isNotNull(ku0071Select001Map))
		{
			super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.EKUB0520AI, new String[]{
					JKUStrConst.SCHEMANM_KU0071,
					"サービス契約番号",
					svcKeiNo});
			
			return null;
		}
		
		// 工事案件番号
		kojiakNo = ku0071Select001Map.getString(JBSbatKU_T_HOJINSVKEI_KJAK.KOJIAK_NO);
		
		// 工事案件PK検索
		ku0011Map = this.findKU_T_KOJIAK(kojiakNo);
		
		// 法人料金グループコード
		String hjprcGrpCd = ku0011Map.getString(JBSbatKU_T_KOJIAK.HOJIN_PRC_GRP_CD);
		
		// 法人サービス契約＿工事案件を更新します。
		this.updateKU_T_HOJINSVKEI_KJAK_PKUPDATE(ku0071Select001Map);
		
		// 法人料金グループコードが未設定の場合(IO⇒HT)、処理を終了する
		if (!JKUBatCommon.isNotNull(hjprcGrpCd))
		{
			return null;
		}
		
		// 工事案件更新
		this.updateKU_T_KOJIAK(inMap, ku0011Map);
		
		// ファイル出力はしないのでnullを返却する
		return null;
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		// DBアクセスクラスをクローズします
		db_KU_T_HOJINSVKEI_KJAK.close();
		db_KU_T_KOJIAK.close();
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
		db_ZM_M_CD_NM_KANRI.close();
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	
	/**
	 * PK(ＰＫ　更新)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数で設定項目マップを作ります。<br>
	 *
	 * 2.引数で条件マップを作ります。<br>
	 *
	 * 3.DBアクセスを実行します。<br>
	 * 
	 * 4.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		setParam:設定したい項目の(項目、値)を(key、value)として、setParamマップに入れます。項目キーは以下に説明します。
	 *		 	回復不可確定年月日				KAIHK_FAIL_FIX_YMD
	 *		whereParam:PK項目の(項目、値)を(key、value)として,格納された配列です。PK項目は以下に説明します。
	 *		 	HJIN_EO_YKAE_SVKEI_NO
	 *		 	KOJIAK_NO
	 * </pre>
	 * <p>
	 * @param setParam 設定項目の値。
	 * @param whereParam 条件項目の値。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeKU_T_HOJINSVKEI_KJAK_PKUPDATE(Object[] setParam, Object[] whereParam) throws Exception
	{
		// 設定値のマップを作成します
		JBSbatCommonDBInterface setMap = new JBSbatCommonDBInterface();
		setMap.setValue("KAIHK_FAIL_FIX_YMD", setParam[0]);
	
		// 条件のマップを作成します
		JBSbatCommonDBInterface whereMap = new JBSbatCommonDBInterface();
		whereMap.setValue("HJIN_EO_YKAE_SVKEI_NO", whereParam[0]);
		whereMap.setValue("KOJIAK_NO", whereParam[1]);

		// DBアクセスを実行します
		db_KU_T_HOJINSVKEI_KJAK.updateByPrimaryKeys(whereMap, setMap);
	}
	
	/**
	 * PK(ＰＫ　更新)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数で設定項目マップを作ります。<br>
	 *
	 * 2.引数で条件マップを作ります。<br>
	 *
	 * 3.DBアクセスを実行します。<br>
	 * 
	 * 4.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		setParam:設定したい項目の(項目、値)を(key、value)として、setParamマップに入れます。項目キーは以下に説明します。
	 *		 	ＳＹＳＩＤ				SYSID
	 *		 	Ｐ−ＩＤ				PID
	 *		 	請求契約番号				SEIKY_KEI_NO
	 *		 	法人料金グループコード				HOJIN_PRC_GRP_CD
	 *		 	法人料金コースコード				HOJIN_PCRS_CD
	 *		 	法人料金プランコード				HOJIN_PPLAN_CD
	 *		 	強制解約工事案件作成要否				KSI_DSL_KOJIAK_SAKSEI_YH
	 *		 	ＦＣＤＳ解約連携要否				FCDS_DSL_RNKI_YH
	 *		 	Ｇｅｎｅｓｉｓ解約連携要否				GENESIS_DSL_RNKI_YH
	 *		 	連携サービス解約種別コード				RNKI_SVC_DSL_SBT_CD
	 *		 	連携サービス終了年月日				RNKI_SVC_ENDYMD
	 *		 	連携サービスキャンセル年月日				RNKI_SVC_CANCEL_YMD
	 *		 	場所番号				PLACE_NO
	 *		 	工事希望年月日				KOJI_KIBO_YMD
	 *		 	転宅先住所コード				TENTAKU_SAKI_AD_CD
	 *		 	転宅先郵便番号				TENTAKU_SAKI_PCD
	 *		 	転宅先都道府県名				TENTAKU_SAKI_STATE_NM
	 *		 	転宅先市区町村名				TENTAKU_SAKI_CITY_NM
	 *		 	転宅先大字通称名				TENTAKU_SAKI_OAZTSU_NM
	 *		 	転宅先字丁目名				TENTAKU_SAKI_AZCHO_NM
	 *		 	転宅先住所番地号				TENTAKU_SAKI_AD_BNCHIGO
	 *		 	転宅先住所補記・建物名				TENTAKU_SAKI_ADRTTM
	 *		 	転宅先住所補記・部屋番号				TENTAKU_SAKI_ADRRM
	 *		 	お客様名				CUST_NM
	 *		 	お客様カナ名				CUST_KANA
	 *		 	お客様自宅電話番号				CUST_HOME_TELNO
	 *		 	お客様携帯電話番号				CUST_KTAI_TELNO
	 *		 	お客様連絡先電話番号				CUST_RRKS_TELNO
	 *		 	連絡先勤務先名				RRKS_OFFC_NM
	 *		 	契約者住所コード				KEISHA_AD_CD
	 *		 	契約者郵便番号				KEISHA_PCD
	 *		 	契約者都道府県名				KEISHA_STATE_NM
	 *		 	契約者市区町村名				KEISHA_CITY_NM
	 *		 	契約者大字通称名				KEISHA_OAZTSU_NM
	 *		 	契約者字丁目名				KEISHA_AZCHO_NM
	 *		 	契約者住所番地号				KEISHA_AD_BNCHIGO
	 *		 	契約者住所補記・建物名				KEISHA_ADRTTM
	 *		 	契約者住所補記・部屋番号				KEISHA_ADRRM
	 *		 	住所形態コード				AD_FORM_CD
	 *		 	工事先住所未確定フラグ				KOJI_SAKI_AD_MI_FIX_FLG
	 *		 	経度				LGTD
	 *		 	緯度				LTTD
	 *		 	入居階数コード				NYUKYO_FLR_CNT_CD
	 *		 	建築階数コード				KCKU_FLR_CNT_CD
	 *		 	方角コード１				DIRECTION_CD_1
	 *		 	方角コード２				DIRECTION_CD_2
	 *		 	工事案件連絡事項				KOJIAK_RRK_JIKO
	 *		 	工事案件備考１				KOJIAK_BIKO_1
	 *		 	工事案件備考２				KOJIAK_BIKO_2
	 *		 	Ｘ座標６系				XZAHYO_6
	 *		 	Ｙ座標６系				YZAHYO_6
	 *		 	Ｘ座標５系				XZAHYO_5
	 *		 	Ｙ座標５系				YZAHYO_5
	 *		whereParam:PK項目の(項目、値)を(key、value)として,格納された配列です。PK項目は以下に説明します。
	 *		 	KOJIAK_NO
	 * </pre>
	 * <p>
	 * @param setParam 設定項目の値。
	 * @param whereParam 条件項目の値。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeKU_T_KOJIAK_PKUPDATE(Object[] setParam, Object[] whereParam) throws Exception
	{
		// 設定値のマップを作成します
		JBSbatCommonDBInterface setMap = new JBSbatCommonDBInterface();
		setMap.setValue("SYSID", setParam[0]);
		setMap.setValue("PID", setParam[1]);
		setMap.setValue("SEIKY_KEI_NO", setParam[2]);
		setMap.setValue("HOJIN_PRC_GRP_CD", setParam[3]);
		setMap.setValue("HOJIN_PCRS_CD", setParam[4]);
		setMap.setValue("HOJIN_PPLAN_CD", setParam[5]);
		setMap.setValue("KSI_DSL_KOJIAK_SAKSEI_YH", setParam[6]);
		setMap.setValue("FCDS_DSL_RNKI_YH", setParam[7]);
		setMap.setValue("GENESIS_DSL_RNKI_YH", setParam[8]);
		setMap.setValue("RNKI_SVC_DSL_SBT_CD", setParam[9]);
		setMap.setValue("RNKI_SVC_ENDYMD", setParam[10]);
		setMap.setValue("RNKI_SVC_CANCEL_YMD", setParam[11]);
		setMap.setValue("PLACE_NO", setParam[12]);
		setMap.setValue("KOJI_KIBO_YMD", setParam[13]);
		setMap.setValue("TENTAKU_SAKI_AD_CD", setParam[14]);
		setMap.setValue("TENTAKU_SAKI_PCD", setParam[15]);
		setMap.setValue("TENTAKU_SAKI_STATE_NM", setParam[16]);
		setMap.setValue("TENTAKU_SAKI_CITY_NM", setParam[17]);
		setMap.setValue("TENTAKU_SAKI_OAZTSU_NM", setParam[18]);
		setMap.setValue("TENTAKU_SAKI_AZCHO_NM", setParam[19]);
		setMap.setValue("TENTAKU_SAKI_AD_BNCHIGO", setParam[20]);
		setMap.setValue("TENTAKU_SAKI_ADRTTM", setParam[21]);
		setMap.setValue("TENTAKU_SAKI_ADRRM", setParam[22]);
		setMap.setValue("CUST_NM", setParam[23]);
		setMap.setValue("CUST_KANA", setParam[24]);
		setMap.setValue("CUST_HOME_TELNO", setParam[25]);
		setMap.setValue("CUST_KTAI_TELNO", setParam[26]);
		setMap.setValue("CUST_RRKS_TELNO", setParam[27]);
		setMap.setValue("RRKS_OFFC_NM", setParam[28]);
		setMap.setValue("KEISHA_AD_CD", setParam[29]);
		setMap.setValue("KEISHA_PCD", setParam[30]);
		setMap.setValue("KEISHA_STATE_NM", setParam[31]);
		setMap.setValue("KEISHA_CITY_NM", setParam[32]);
		setMap.setValue("KEISHA_OAZTSU_NM", setParam[33]);
		setMap.setValue("KEISHA_AZCHO_NM", setParam[34]);
		setMap.setValue("KEISHA_AD_BNCHIGO", setParam[35]);
		setMap.setValue("KEISHA_ADRTTM", setParam[36]);
		setMap.setValue("KEISHA_ADRRM", setParam[37]);
		setMap.setValue("AD_FORM_CD", setParam[38]);
		setMap.setValue("KOJI_SAKI_AD_MI_FIX_FLG", setParam[39]);
		setMap.setValue("LGTD", setParam[40]);
		setMap.setValue("LTTD", setParam[41]);
		setMap.setValue("NYUKYO_FLR_CNT_CD", setParam[42]);
		setMap.setValue("KCKU_FLR_CNT_CD", setParam[43]);
		setMap.setValue("DIRECTION_CD_1", setParam[44]);
		setMap.setValue("DIRECTION_CD_2", setParam[45]);
		setMap.setValue("KOJIAK_RRK_JIKO", setParam[46]);
		setMap.setValue("KOJIAK_BIKO_1", setParam[47]);
		setMap.setValue("KOJIAK_BIKO_2", setParam[48]);
		setMap.setValue("XZAHYO_6", setParam[49]);
		setMap.setValue("YZAHYO_6", setParam[50]);
		setMap.setValue("XZAHYO_5", setParam[51]);
		setMap.setValue("YZAHYO_5", setParam[52]);
	
		// 条件のマップを作成します
		JBSbatCommonDBInterface whereMap = new JBSbatCommonDBInterface();
		whereMap.setValue("KOJIAK_NO", whereParam[0]);

		// DBアクセスを実行します
		db_KU_T_KOJIAK.updateByPrimaryKeys(whereMap, setMap);
	}

	/**
	 * SQLKEY(KU_SELECT_001)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	法人eo読替サービス契約番号
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeKU_T_HOJINSVKEI_KJAK_KU_SELECT_001(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());

		// DBアクセスを実行します
		db_KU_T_HOJINSVKEI_KJAK.selectBySqlDefine(paramList, KU_T_HOJINSVKEI_KJAK_KU_SELECT_001);
	}

	/**
	 * PK(ＰＫ　検索)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数で条件マップを作ります。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		whereParam:PK項目の(項目、値)を(key、value)として,格納された配列です。PK項目は以下に説明します。
	 *		 	KOJIAK_NO
	 * </pre>
	 * <p>
	 * @param whereParam 条件項目の値。
	 * @return JBSbatCommonDBInterface 検索の結果。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private JBSbatCommonDBInterface executeKU_T_KOJIAK_PKSELECT(Object[] whereParam) throws Exception
	{
		// 条件のマップを作成します
		JBSbatCommonDBInterface whereMap = new JBSbatCommonDBInterface();
		whereMap.setValue("KOJIAK_NO", whereParam[0]);

		// DBアクセスを実行します
		return db_KU_T_KOJIAK.selectByPrimaryKeys(whereMap);
	}
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/

	/**▼▼▼▼▼▼業務チームで作成したメソッドです 開始▼▼▼▼▼▼*/
	
	/**
	 *入力情報（回復不可契約情報受信（法人））の単項目チェックを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.単項目チェックを行います。<br>
	 * 
	 * 2.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		rsMap:(項目、値)を(key、value)として、データをrsMapに入れます
	 *		itemvalueMap:埋め込み文字の値をitemvalueMapに入れます。キーの値は、以下に説明します。
	 *			 TXT-KUIFE044-INF1.REC_SBT			回復不可契約情報受信（法人）.レコード種別
	 *			 TXT-KUIFE044-INF1.REC_SBT			回復不可契約情報受信（法人）.レコード種別
	 *			 TXT-KUIFE044-INF1.REC_SBT			回復不可契約情報受信（法人）.レコード種別
	 *			 TXT-KUIFE044-INF1.SVC_KEI_NO			回復不可契約情報受信（法人）.サービス契約番号
	 *			 TXT-KUIFE044-INF1.SVC_KEI_NO			回復不可契約情報受信（法人）.サービス契約番号
	 *			 TXT-KUIFE044-INF1.SVC_KEI_NO			回復不可契約情報受信（法人）.サービス契約番号
	 *			 TXT-KUIFE044-INF1.SVC_ENDYMD			回復不可契約情報受信（法人）.サービス終了年月日
	 *			 TXT-KUIFE044-INF1.SVC_ENDYMD			回復不可契約情報受信（法人）.サービス終了年月日
	 *			 TXT-KUIFE044-INF1.SVC_ENDYMD			回復不可契約情報受信（法人）.サービス終了年月日
	 *			 TXT-KUIFE044-INF1.SVC_DSL_SBT_CD			回復不可契約情報受信（法人）.サービス解約種別コード
	 *			 TXT-KUIFE044-INF1.SVC_DSL_SBT_CD			回復不可契約情報受信（法人）.サービス解約種別コード
	 *			 TXT-KUIFE044-INF1.SVC_DSL_SBT_CD			回復不可契約情報受信（法人）.サービス解約種別コード
	 *			 TXT-KUIFE044-INF1.SYSID			回復不可契約情報受信（法人）.ＳＹＳＩＤ
	 *			 TXT-KUIFE044-INF1.SYSID			回復不可契約情報受信（法人）.ＳＹＳＩＤ
	 *			 TXT-KUIFE044-INF1.SYSID			回復不可契約情報受信（法人）.ＳＹＳＩＤ
	 * </pre>
	 * <p>
	 * @param rsMap 入力データ（TXT又はDB）を格納されたHashMap。
	 * @param itemvalueMap エラーメッセージに関する項目値を格納されたHashMap。
	 * @return  boolean trueである場合、エラーがありません。falseである場合、エラーを発生しました。
	 */
	private boolean isSingleCheckKUIFE044_INF1_Mdf(HashMap rsMap, HashMap itemvalueMap)
	{
		// 単項目チェックを行います
		String strValue = null;

		// レコード種別項目チェック
		strValue = (String)rsMap.get("REC_SBT");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKUB0010TE", new String[]{
															(String)itemvalueMap.get("TXT-KUIFE044-INF1.REC_SBT")});
			return false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "1", "1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKUB0050TE", new String[]{
															(String)itemvalueMap.get("TXT-KUIFE044-INF1.REC_SBT"),
															strValue});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKUB0160TE", new String[]{
															(String)itemvalueMap.get("TXT-KUIFE044-INF1.REC_SBT"),
															strValue});
			return false;
		}

		// サービス契約番号項目チェック
		strValue = (String)rsMap.get("SVC_KEI_NO");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKUB0010TE", new String[]{
															(String)itemvalueMap.get("TXT-KUIFE044-INF1.SVC_KEI_NO")});
			return false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "10", "10"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKUB0050TE", new String[]{
															(String)itemvalueMap.get("TXT-KUIFE044-INF1.SVC_KEI_NO"),
															strValue});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKUB0160TE", new String[]{
															(String)itemvalueMap.get("TXT-KUIFE044-INF1.SVC_KEI_NO"),
															strValue});
			return false;
		}

		// サービス終了年月日項目チェック
		strValue = (String)rsMap.get("SVC_ENDYMD");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKUB0010TE", new String[]{
															(String)itemvalueMap.get("TXT-KUIFE044-INF1.SVC_ENDYMD")});
			return false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "8", "8"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKUB0050TE", new String[]{
															(String)itemvalueMap.get("TXT-KUIFE044-INF1.SVC_ENDYMD"),
															strValue});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"year_month_day1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKUB0160TE", new String[]{
															(String)itemvalueMap.get("TXT-KUIFE044-INF1.SVC_ENDYMD"),
															strValue});
			return false;
		}

		// サービス解約種別コード項目チェック
		strValue = (String)rsMap.get("SVC_DSL_SBT_CD");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKUB0010TE", new String[]{
															(String)itemvalueMap.get("TXT-KUIFE044-INF1.SVC_DSL_SBT_CD")});
			return false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "1", "1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKUB0050TE", new String[]{
															(String)itemvalueMap.get("TXT-KUIFE044-INF1.SVC_DSL_SBT_CD"),
															strValue});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKUB0160TE", new String[]{
															(String)itemvalueMap.get("TXT-KUIFE044-INF1.SVC_DSL_SBT_CD"),
															strValue});
			return false;
		}

		// ＳＹＳＩＤ項目チェック
		strValue = (String)rsMap.get("SYSID");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKUB0010TE", new String[]{
															(String)itemvalueMap.get("TXT-KUIFE044-INF1.SYSID")});
			return false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "8", "8"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKUB0050TE", new String[]{
															(String)itemvalueMap.get("TXT-KUIFE044-INF1.SYSID"),
															strValue});
			return false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKUB0160TE", new String[]{
															(String)itemvalueMap.get("TXT-KUIFE044-INF1.SYSID"),
															strValue});
			return false;
		}

		return true;
	}
	
	/**
	 * コードマスタの存在チェックを行います。
	 * @param rsMap 入力データ（TXT又はDB）を格納されたHashMap。
	 * @param itemvalueMap エラーメッセージに関する項目値を格納されたHashMap。
	 * @return boolean trueである場合、エラーがありません。falseである場合、エラーを発生しました。
	 * @throws Exception
	 */
	private boolean isCodeCheck(HashMap rsMap, HashMap itemvalueMap) throws Exception
	{
		// チェック対象
		String strValue = null;
		
		// チェックリターンフラグ
		boolean returnFlg = true;

		// サービス解約種別コード
		strValue = (String)rsMap.get(JBSbatKUIFE044.SVC_DSL_SBT_CD);
		if(JKUBatCommon.isNotNull(strValue) && !JKUBatCommon.isCodeMaster(db_ZM_M_CD_NM_KANRI, commonItem, strValue, JZM0171Constant.CD00693))
		{
			// %1%はコードが不正です。（%2%）
			commonItem.getLogPrint().printBusinessErrorLog(JPCBatchMessageConstant.EKUB0130TE, new String[]{
															(String)itemvalueMap.get("TXT-KUIFE044-INF1.SVC_DSL_SBT_CD"),
															strValue});
			returnFlg = false;
		}
		
		return returnFlg;
	}
	
	/**
	 * 項目チェックで使用するitemvalueMapを生成します。
	 * HashMap<String,String> 項目名が格納されたHashMap。
	 * @return messageMap 埋め込み文字の値。
	 */
	private HashMap<String, String> createMessageMap()
	{
		HashMap<String, String> retMap = new HashMap<String, String>();
		
		retMap.put("TXT-KUIFE044-INF1.REC_SBT", "回復不可契約情報受信（法人）.レコード種別");
		retMap.put("TXT-KUIFE044-INF1.SVC_KEI_NO", "回復不可契約情報受信（法人）.サービス契約番号");
		retMap.put("TXT-KUIFE044-INF1.SVC_ENDYMD", "回復不可契約情報受信（法人）.サービス終了年月日");
		retMap.put("TXT-KUIFE044-INF1.SVC_DSL_SBT_CD", "回復不可契約情報受信（法人）.サービス解約種別コード");
		retMap.put("TXT-KUIFE044-INF1.PRC_GRP_CD", "回復不可契約情報受信（法人）.料金グループコード");
		retMap.put("TXT-KUIFE044-INF1.PCRS_CD", "回復不可契約情報受信（法人）.料金コースコード");
		retMap.put("TXT-KUIFE044-INF1.PPLAN_CD", "回復不可契約情報受信（法人）.料金プランコード");
		retMap.put("TXT-KUIFE044-INF1.SYSID", "回復不可契約情報受信（法人）.ＳＹＳＩＤ");
		retMap.put("TXT-KUIFE044-INF1.CUST_NM", "回復不可契約情報受信（法人）.お客様名");
		retMap.put("TXT-KUIFE044-INF1.CUST_KANA", "回復不可契約情報受信（法人）.お客様カナ名");
		retMap.put("TXT-KUIFE044-INF1.CUST_HOME_TELNO", "回復不可契約情報受信（法人）.お客様自宅電話番号");
		retMap.put("TXT-KUIFE044-INF1.CUST_KTAI_TELNO", "回復不可契約情報受信（法人）.お客様携帯電話番号");
		retMap.put("TXT-KUIFE044-INF1.CUST_RRKS_TELNO", "回復不可契約情報受信（法人）.お客様連絡先電話番号");
		retMap.put("TXT-KUIFE044-INF1.RRKS_OFFC_NM", "回復不可契約情報受信（法人）.連絡先勤務先名");
		retMap.put("TXT-KUIFE044-INF1.KEISHA_AD_CD", "回復不可契約情報受信（法人）.契約者住所コード");
		retMap.put("TXT-KUIFE044-INF1.KEISHA_PCD", "回復不可契約情報受信（法人）.契約者郵便番号");
		retMap.put("TXT-KUIFE044-INF1.KEISHA_STATE_NM", "回復不可契約情報受信（法人）.契約者都道府県名");
		retMap.put("TXT-KUIFE044-INF1.KEISHA_CITY_NM", "回復不可契約情報受信（法人）.契約者市区町村名");
		retMap.put("TXT-KUIFE044-INF1.KEISHA_OAZTSU_NM", "回復不可契約情報受信（法人）.契約者大字通称名");
		retMap.put("TXT-KUIFE044-INF1.KEISHA_AZCHO_NM", "回復不可契約情報受信（法人）.契約者字丁目名");
		retMap.put("TXT-KUIFE044-INF1.KEISHA_AD_BNCHIGO", "回復不可契約情報受信（法人）.契約者住所番地号");
		retMap.put("TXT-KUIFE044-INF1.KEISHA_ADRTTM", "回復不可契約情報受信（法人）.契約者住所補記・建物名");
		retMap.put("TXT-KUIFE044-INF1.KEISHA_ADRRM", "回復不可契約情報受信（法人）.契約者住所補記・部屋番号");
		retMap.put("TXT-KUIFE044-INF1.SEIKY_KEI_NO", "回復不可契約情報受信（法人）.請求契約番号");
		retMap.put("TXT-KUIFE044-INF1.PLACE_NO", "回復不可契約情報受信（法人）.場所番号");
		retMap.put("TXT-KUIFE044-INF1.SETPLACE_AD_CD", "回復不可契約情報受信（法人）.設置場所住所コード");
		retMap.put("TXT-KUIFE044-INF1.SETPLACE_PCD", "回復不可契約情報受信（法人）.設置場所郵便番号");
		retMap.put("TXT-KUIFE044-INF1.SETPLACE_STATE_NM", "回復不可契約情報受信（法人）.設置場所都道府県名");
		retMap.put("TXT-KUIFE044-INF1.SETPLACE_CITY_NM", "回復不可契約情報受信（法人）.設置場所市区町村名");
		retMap.put("TXT-KUIFE044-INF1.SETPLACE_OAZTSU_NM", "回復不可契約情報受信（法人）.設置場所大字通称名");
		retMap.put("TXT-KUIFE044-INF1.SETPLACE_AZCHO_NM", "回復不可契約情報受信（法人）.設置場所字丁目名");
		retMap.put("TXT-KUIFE044-INF1.SETPLACE_AD_BNCHIGO", "回復不可契約情報受信（法人）.設置場所住所番地号");
		retMap.put("TXT-KUIFE044-INF1.SETPLACE_ADRTTM", "回復不可契約情報受信（法人）.設置場所住所補記・建物名");
		retMap.put("TXT-KUIFE044-INF1.SETPLACE_ADRRM", "回復不可契約情報受信（法人）.設置場所住所補記・部屋番号");
		retMap.put("TXT-KUIFE044-INF1.KOJI_SAKI_AD_MI_FIX_FLG", "回復不可契約情報受信（法人）.工事先住所未確定フラグ");
		retMap.put("TXT-KUIFE044-INF1.LGTD", "回復不可契約情報受信（法人）.経度");
		retMap.put("TXT-KUIFE044-INF1.LTTD", "回復不可契約情報受信（法人）.緯度");
		retMap.put("TXT-KUIFE044-INF1.AD_FORM_CD", "回復不可契約情報受信（法人）.住所形態コード");
		retMap.put("TXT-KUIFE044-INF1.NYUKYO_FLR_CNT_CD", "回復不可契約情報受信（法人）.入居階数コード");
		retMap.put("TXT-KUIFE044-INF1.KCKU_FLR_CNT_CD", "回復不可契約情報受信（法人）.建築階数コード");
		retMap.put("TXT-KUIFE044-INF1.DIRECTION_CD_1", "回復不可契約情報受信（法人）.方角コード１");
		retMap.put("TXT-KUIFE044-INF1.DIRECTION_CD_2", "回復不可契約情報受信（法人）.方角コード２");
		retMap.put("TXT-KUIFE044-INF1.KOJI_SCOPE_CD", "回復不可契約情報受信（法人）.工事範囲コード");
		retMap.put("TXT-KUIFE044-INF1.KOJI_KIBO_YMD", "回復不可契約情報受信（法人）.工事希望年月日");
		retMap.put("TXT-KUIFE044-INF1.DSL_KIBO_YMD", "回復不可契約情報受信（法人）.解約希望年月日");
		retMap.put("TXT-KUIFE044-INF1.KOJIAK_BIKO", "回復不可契約情報受信（法人）.工事案件備考");
		retMap.put("TXT-KUIFE044-INF1.KOJIAK_BIKO_1", "回復不可契約情報受信（法人）.工事案件備考１");
		retMap.put("TXT-KUIFE044-INF1.KOJIAK_BIKO_2", "回復不可契約情報受信（法人）.工事案件備考２");
		retMap.put("TXT-KUIFE044-INF1.PID", "回復不可契約情報受信（法人）.Ｐ−ＩＤ");
		retMap.put("TXT-KUIFE044-INF1.MENKAIHAT_ANKEN_NO", "回復不可契約情報受信（法人）.面開発案件番号");
		retMap.put("TXT-KUIFE044-INF1.MNKHT_KOJI_CD", "回復不可契約情報受信（法人）.面開発工事コード");
		retMap.put("TXT-KUIFE044-INF1.DMPSANK_SBT_CD", "回復不可契約情報受信（法人）.電波障害案件種別コード");
		retMap.put("TXT-KUIFE044-INF1.TAKNKIKI_MODEL_CD_ONU", "回復不可契約情報受信（法人）.宅内機器型式コード＿ＯＮＵ");
		retMap.put("TXT-KUIFE044-INF1.MACAD_ONU", "回復不可契約情報受信（法人）.ＭＡＣアドレス＿ＯＮＵ");
		retMap.put("TXT-KUIFE044-INF1.TAKNKIKI_MODEL_CD_VA", "回復不可契約情報受信（法人）.宅内機器型式コード＿ＶＡ");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_VA", "回復不可契約情報受信（法人）.機器製造番号＿ＶＡ");
		retMap.put("TXT-KUIFE044-INF1.TAKNKIKI_MODEL_CD_EOPHONE", "回復不可契約情報受信（法人）.宅内機器型式コード＿ｅｏフォン");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_EOPHONE", "回復不可契約情報受信（法人）.機器製造番号＿ｅｏフォン");
		retMap.put("TXT-KUIFE044-INF1.TAKNKIKI_MODEL_CD_ROUTER", "回復不可契約情報受信（法人）.宅内機器型式コード＿ルーター");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_ROUTER", "回復不可契約情報受信（法人）.機器製造番号＿ルーター");
		retMap.put("TXT-KUIFE044-INF1.TAKNKIKI_MODEL_CD_PLC_1", "回復不可契約情報受信（法人）.宅内機器型式コード＿ＰＬＣ１");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_PLC_1", "回復不可契約情報受信（法人）.機器製造番号＿ＰＬＣ１");
		retMap.put("TXT-KUIFE044-INF1.TAKNKIKI_MODEL_CD_PLC_2", "回復不可契約情報受信（法人）.宅内機器型式コード＿ＰＬＣ２");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_PLC_2", "回復不可契約情報受信（法人）.機器製造番号＿ＰＬＣ２");
		retMap.put("TXT-KUIFE044-INF1.TAKNKIKI_MODEL_CD_PLC_3", "回復不可契約情報受信（法人）.宅内機器型式コード＿ＰＬＣ３");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_PLC_3", "回復不可契約情報受信（法人）.機器製造番号＿ＰＬＣ３");
		retMap.put("TXT-KUIFE044-INF1.TAKNKIKI_MODEL_CD_PLC_4", "回復不可契約情報受信（法人）.宅内機器型式コード＿ＰＬＣ４");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_PLC_4", "回復不可契約情報受信（法人）.機器製造番号＿ＰＬＣ４");
		retMap.put("TXT-KUIFE044-INF1.TAKNKIKI_MODEL_CD_PLC_5", "回復不可契約情報受信（法人）.宅内機器型式コード＿ＰＬＣ５");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_PLC_5", "回復不可契約情報受信（法人）.機器製造番号＿ＰＬＣ５");
		retMap.put("TXT-KUIFE044-INF1.TAKNKIKI_MODEL_CD_PLC_6", "回復不可契約情報受信（法人）.宅内機器型式コード＿ＰＬＣ６");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_PLC_6", "回復不可契約情報受信（法人）.機器製造番号＿ＰＬＣ６");
		retMap.put("TXT-KUIFE044-INF1.TAKNKIKI_MODEL_CD_PLC_7", "回復不可契約情報受信（法人）.宅内機器型式コード＿ＰＬＣ７");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_PLC_7", "回復不可契約情報受信（法人）.機器製造番号＿ＰＬＣ７");
		retMap.put("TXT-KUIFE044-INF1.TAKNKIKI_MODEL_CD_PLC_8", "回復不可契約情報受信（法人）.宅内機器型式コード＿ＰＬＣ８");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_PLC_8", "回復不可契約情報受信（法人）.機器製造番号＿ＰＬＣ８");
		retMap.put("TXT-KUIFE044-INF1.TAKNKIKI_MODEL_CD_VONU", "回復不可契約情報受信（法人）.宅内機器型式コード＿Ｖ−ＯＮＵ");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_VONU", "回復不可契約情報受信（法人）.機器製造番号＿Ｖ−ＯＮＵ");
		retMap.put("TXT-KUIFE044-INF1.STB_ID_1", "回復不可契約情報受信（法人）.ＳＴＢ−ＩＤ１");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_BCAS_1", "回復不可契約情報受信（法人）.機器製造番号＿Ｂ−ＣＡＳ１");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_CCAS_1", "回復不可契約情報受信（法人）.機器製造番号＿Ｃ−ＣＡＳ１");
		retMap.put("TXT-KUIFE044-INF1.STB_ID_2", "回復不可契約情報受信（法人）.ＳＴＢ−ＩＤ２");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_BCAS_2", "回復不可契約情報受信（法人）.機器製造番号＿Ｂ−ＣＡＳ２");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_CCAS_2", "回復不可契約情報受信（法人）.機器製造番号＿Ｃ−ＣＡＳ２");
		retMap.put("TXT-KUIFE044-INF1.STB_ID_3", "回復不可契約情報受信（法人）.ＳＴＢ−ＩＤ３");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_BCAS_3", "回復不可契約情報受信（法人）.機器製造番号＿Ｂ−ＣＡＳ３");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_CCAS_3", "回復不可契約情報受信（法人）.機器製造番号＿Ｃ−ＣＡＳ３");
		retMap.put("TXT-KUIFE044-INF1.STB_ID_4", "回復不可契約情報受信（法人）.ＳＴＢ−ＩＤ４");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_BCAS_4", "回復不可契約情報受信（法人）.機器製造番号＿Ｂ−ＣＡＳ４");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_CCAS_4", "回復不可契約情報受信（法人）.機器製造番号＿Ｃ−ＣＡＳ４");
		retMap.put("TXT-KUIFE044-INF1.STB_ID_5", "回復不可契約情報受信（法人）.ＳＴＢ−ＩＤ５");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_BCAS_5", "回復不可契約情報受信（法人）.機器製造番号＿Ｂ−ＣＡＳ５");
		retMap.put("TXT-KUIFE044-INF1.KIKI_SEIZO_NO_CCAS_5", "回復不可契約情報受信（法人）.機器製造番号＿Ｃ−ＣＡＳ５");
		
		return retMap;
		
	}

	/**
	 * 工事案件を検索します。
	 * @param kojiakNo 工事案件番号
	 * @return 工事案件テーブル１レコード（取得できなかった場合はnull）
	 * @throws Exception
	 */
	private JBSbatCommonDBInterface findKU_T_KOJIAK(String kojiakNo) throws Exception
	{
		// 検索処理に渡すパラメタを設定
		Object[] whereParam = new Object[1];
		
		whereParam[0] = kojiakNo;
		
		// 検索処理実行
		JBSbatCommonDBInterface ku0011Map = this.executeKU_T_KOJIAK_PKSELECT(whereParam);
		
		// 工事案件が存在しない場合、次レコードへ
		if(null == ku0011Map)
		{
			// ログ出力し、次レコードへ
			super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.EKUB0650KW, new String[]{
					JKUStrConst.SCHEMANM_KU0011,
					"工事案件番号",
					kojiakNo});
			
			throw new JBSbatBusinessError();
		}
		
		return ku0011Map;
	}	
	
	/**
	 * 法人サービス契約＿工事案件をサービス契約番号をキーに検索します。
	 * @param arg0 サービス契約番号
	 * @return 法人サービス契約＿工事案件１レコード（取得できなかった場合はnull）
	 * @throws Exception 
	 */
	private JBSbatCommonDBInterface findKU_T_HOJINSVKEI_KJAK_KU_SELECT_001(String arg0) throws Exception
	{
		Object[] whereParam = new Object[1];
		
		whereParam[0] = arg0;
		
		// 検索処理実行
		this.executeKU_T_HOJINSVKEI_KJAK_KU_SELECT_001(whereParam);
		
		return db_KU_T_HOJINSVKEI_KJAK.selectNext();
	}
	
	/**
	 * 法人サービス契約＿工事案件を更新します。
	 * @param ku0071Map 法人サービス契約＿工事案件マップ
	 * @throws Exception
	 */
	private void updateKU_T_HOJINSVKEI_KJAK_PKUPDATE(JBSbatCommonDBInterface ku0071Map) throws Exception
	{
		// 更新処理に渡すパラメタを設定
		Object[] setParam = new Object[1];
		Object[] whereParam = new Object[2];
		
		// 工事案件ステータス
		
		// 回復不可確定年月日
		setParam[0] = commonItem.getOpeDate();
		
		// サービス契約番号
		whereParam[0] = ku0071Map.getString(JBSbatKU_T_HOJINSVKEI_KJAK.HJIN_EO_YKAE_SVKEI_NO);
		
		// 工事案件番号
		whereParam[1] = ku0071Map.getString(JBSbatKU_T_HOJINSVKEI_KJAK.KOJIAK_NO);
		
		this.executeKU_T_HOJINSVKEI_KJAK_PKUPDATE(setParam, whereParam);
		
	}

	/**
	 * 工事案件を更新します。
	 * @param inMap 入力電文
	 * @param ku0011Map 工事案件マップ
	 * @throws Exception
	 */
	private void updateKU_T_KOJIAK(JBSbatServiceInterfaceMap inMap, JBSbatCommonDBInterface ku0011Map) throws Exception
	{
		// 更新処理に渡すパラメタを設定
		Object[] setParam = new Object[53];
		Object[] whereParam = new Object[1];
		
		// 更新項目の設定
		// SYSID
		setParam[0] = JKUStrConst.HOJIN_SYSID_HEADER + inMap.getString(JBSbatKUIFE044.SYSID);
		
		// 強制解約工事案件作成要否
		setParam[6] = JKUStrConst.KH_FAIL;
		
		/** ＦＣＤＳ解約連携要否 */
		String fcdsDslRkYh = JKUStrConst.KH_PSG;
		
		// ＦＣＤＳ連携種別コードが「連携済」又は「工事完了連携済」以外の場合
		if (!(JKUStrConst.CD00699_RENKEIZM.equals(ku0011Map.getString(JBSbatKU_T_KOJIAK.FCDS_RNKI_SBT_CD)) || 
				JKUStrConst.CD00699_KOJI_FIN_RENKEIZM.equals(ku0011Map.getString(JBSbatKU_T_KOJIAK.FCDS_RNKI_SBT_CD))))
		{
			fcdsDslRkYh =JKUStrConst.KH_FAIL;
		}
		
		// FCDS解約連携要否
		setParam[7] = fcdsDslRkYh;
		
		/** Ｇｅｎｅｓｉｓ解約連携要否 */
		String geneDslRkYh = JKUStrConst.KH_PSG;
		
		// Ｇｅｎｅｓｉｓ連携種別コードが「連携済」又は「工事完了連携済」以外の場合
		if (!(JKUStrConst.CD00699_RENKEIZM.equals(ku0011Map.getString(JBSbatKU_T_KOJIAK.GENESIS_RNKI_SBT_CD)) || 
				JKUStrConst.CD00699_KOJI_FIN_RENKEIZM.equals(ku0011Map.getString(JBSbatKU_T_KOJIAK.GENESIS_RNKI_SBT_CD))))
		{
			geneDslRkYh =JKUStrConst.KH_FAIL;
		}
		
		// Genesis解約連携要否
		setParam[8] = geneDslRkYh;
		
		// 連携サービス解約種別コード
		setParam[9] = inMap.getString(JBSbatKUIFE044.SVC_DSL_SBT_CD);
		
		// 連携サービス終了年月日
		if(JKUStrConst.CD00693_DSL.equals(inMap.getString(JBSbatKUIFE044.SVC_DSL_SBT_CD))
				|| JKUStrConst.CD00693_KSI_DSL.equals(inMap.getString(JBSbatKUIFE044.SVC_DSL_SBT_CD)))
		{
			setParam[10] = inMap.getString(JBSbatKUIFE044.SVC_ENDYMD);
		}
		else
		{
			setParam[10] = "";
		}
		
		// 連携サービスキャンセル年月日
		if(JKUStrConst.CD00693_CNCL.equals(inMap.getString(JBSbatKUIFE044.SVC_DSL_SBT_CD)))
		{
			setParam[11] = inMap.getString(JBSbatKUIFE044.SVC_ENDYMD);
		}
		else
		{
			setParam[11] = "";
		}
		
		
		// 条件項目の設定
		// 工事案件番号
		whereParam[0] = ku0011Map.getString(JBSbatKU_T_KOJIAK.KOJIAK_NO);
		
		this.executeKU_T_KOJIAK_PKUPDATE(setParam, whereParam);
		
	}
	/**▲▲▲▲▲▲業務チームで作成したメソッドです 終了▲▲▲▲▲▲*/

}
