/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatKKMansRsvIfCheck
*	ソースファイル名	：JBSbatKKMansRsvIfCheck.java
*	作成者				：富士通　
*	作成日				：2012年05月23日
*＜機能概要＞
*　マンション受信情報チェック部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2012/05/23   富士通		新規作成
*********************************************************************/
package eo.business.service;

import java.util.HashMap;

import eo.business.common.JBSbatBusinessService;
import eo.business.common.JKKBatConst;
import eo.business.util.file.JBSbatKKIFM199;
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.JBSbatCheckUtil;

/**
* (クラスの機能概要) <p>
*<BR>
* @author 富士通
*/
public class JBSbatKKMansRsvIfCheck extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/** テーブル(マンション物件)*/
	private static final String D_TBL_NAME_KK_T_MANSION_BUKKEN = "KK_T_MANSION_BUKKEN";

	/** テーブル(マンションオーナー)*/
	private static final String D_TBL_NAME_CK_T_MANSION_OWNR = "CK_T_MANSION_OWNR";

	/** テーブル(オーナー契約)*/
	private static final String D_TBL_NAME_KK_T_OWNR_KEI = "KK_T_OWNR_KEI";

	/** テーブル(コード名称管理)*/
	private static final String D_TBL_NAME_ZM_M_CD_NM_KANRI = "ZM_M_CD_NM_KANRI";

	/** テーブル(住所)*/
	private static final String D_TBL_NAME_ZM_M_AD = "ZM_M_AD";

	/** SQL定義キー(KK_SELECT_001)*/
	private static final String KK_T_MANSION_BUKKEN_KK_SELECT_001 = "KK_SELECT_001";

	/** SQL定義キー(KK_SELECT_001)*/
	private static final String CK_T_MANSION_OWNR_KK_SELECT_001 = "KK_SELECT_001";

	/** SQL定義キー(KK_SELECT_003)*/
	private static final String ZM_M_CD_NM_KANRI_KK_SELECT_003 = "KK_SELECT_003";

	/** SQL定義キー(KK_SELECT_005)*/
	private static final String ZM_M_AD_KK_SELECT_005 = "KK_SELECT_005";

	/** SQL定義キー(KK_SELECT_007)*/
	private static final String KK_T_OWNR_KEI_KK_SELECT_007 = "KK_SELECT_007";

	/** SQL定義キー(KK_SELECT_009)*/
	private static final String KK_T_OWNR_KEI_KK_SELECT_009 = "KK_SELECT_009";

	/** テーブルアクセスクラス(マンション物件)*/
	private JBSbatSQLAccess db_KK_T_MANSION_BUKKEN = null;

	/** テーブルアクセスクラス(マンションオーナー)*/
	private JBSbatSQLAccess db_CK_T_MANSION_OWNR = null;

	/** テーブルアクセスクラス(オーナー契約)*/
	private JBSbatSQLAccess db_KK_T_OWNR_KEI = null;

	/** テーブルアクセスクラス(コード名称管理)*/
	private JBSbatSQLAccess db_ZM_M_CD_NM_KANRI = null;

	/** テーブルアクセスクラス(住所)*/
	private JBSbatSQLAccess db_ZM_M_AD = null;
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/

	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);

		// DBアクセスクラスを生成します
		db_KK_T_OWNR_KEI = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KK_T_OWNR_KEI);
		db_KK_T_MANSION_BUKKEN = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KK_T_MANSION_BUKKEN);
		db_CK_T_MANSION_OWNR = new JBSbatSQLAccess(commonItem, D_TBL_NAME_CK_T_MANSION_OWNR);
		db_ZM_M_CD_NM_KANRI = new JBSbatSQLAccess(commonItem, D_TBL_NAME_ZM_M_CD_NM_KANRI);
		db_ZM_M_AD = new JBSbatSQLAccess(commonItem, D_TBL_NAME_ZM_M_AD);
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @param inMap　入力電文
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute(JBSbatServiceInterfaceMap inMap) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		// 出力共通電文を生成する。
		JBSbatOutputItem outputBean = new JBSbatOutputItem();

		// 単項目チェック(レイアウトチェック) 順序、要確認
		if(!isSingleCheckKKIFM199_INF1(inMap.getMap(), getItemvalueMap()))
		{
			outputBean.addOutMapList_2(setRcvInfo(inMap));
			return outputBean;
		}
		//存在チェック
		if(!checkExist(inMap))
		{
			outputBean.addOutMapList_2(setRcvInfo(inMap));
			return outputBean;
		}
		//相関チェック
		if(!checkCorrelation(inMap))
		{
			outputBean.addOutMapList_2(setRcvInfo(inMap));
			return outputBean;
		}

		outputBean.addOutMapList(setRcvInfo(inMap));
		return outputBean;
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		// DBアクセスクラスをクローズします
		db_KK_T_OWNR_KEI.close();
		db_KK_T_MANSION_BUKKEN.close();
		db_CK_T_MANSION_OWNR.close();
		db_ZM_M_CD_NM_KANRI.close();
		db_ZM_M_AD.close();
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	/**
	 *入力情報（マンションオーナー情報作成）の単項目チェックを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.単項目チェックを行います。<br>
	 * 
	 * 2.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		rsMap:(項目、値)を(key、value)として、データをrsMapに入れます
	 *		itemvalueMap:埋め込み文字の値をitemvalueMapに入れます。キーの値は、以下に説明します。
	 *			 TXT-KKIFM199-INF1.TRAN_DIV			マンションオーナー情報作成.処理区分
	 *			 TXT-KKIFM199-INF1.TRAN_DIV			マンションオーナー情報作成.処理区分
	 *			 TXT-KKIFM199-INF1.TRAN_DIV			マンションオーナー情報作成.処理区分
	 *			 TXT-KKIFM199-INF1.PID			マンションオーナー情報作成.Ｐ−ＩＤ
	 *			 TXT-KKIFM199-INF1.PID			マンションオーナー情報作成.Ｐ−ＩＤ
	 *			 TXT-KKIFM199-INF1.PID			マンションオーナー情報作成.Ｐ−ＩＤ
	 *			 TXT-KKIFM199-INF1.PID_ADD_YMD			マンションオーナー情報作成.Ｐ−ＩＤ登録年月日
	 *			 TXT-KKIFM199-INF1.PID_ADD_YMD			マンションオーナー情報作成.Ｐ−ＩＤ登録年月日
	 *			 TXT-KKIFM199-INF1.PID_ADD_YMD			マンションオーナー情報作成.Ｐ−ＩＤ登録年月日
	 *			 TXT-KKIFM199-INF1.BUSINESS_SHT_TYPE			マンションオーナー情報作成.ビジネスシートタイプ
	 *			 TXT-KKIFM199-INF1.BUSINESS_SHT_TYPE			マンションオーナー情報作成.ビジネスシートタイプ
	 *			 TXT-KKIFM199-INF1.BUSINESS_SHT_TYPE			マンションオーナー情報作成.ビジネスシートタイプ
	 *			 TXT-KKIFM199-INF1.KNRI_TIKI_CD			マンションオーナー情報作成.管理体系コード
	 *			 TXT-KKIFM199-INF1.KNRI_TIKI_CD			マンションオーナー情報作成.管理体系コード
	 *			 TXT-KKIFM199-INF1.KSH_NM_KN			マンションオーナー情報作成.契約者名（カナ）
	 *			 TXT-KKIFM199-INF1.KSH_NM_KN			マンションオーナー情報作成.契約者名（カナ）
	 *			 TXT-KKIFM199-INF1.KSH_NM			マンションオーナー情報作成.契約者名
	 *			 TXT-KKIFM199-INF1.KSH_NM			マンションオーナー情報作成.契約者名
	 *			 TXT-KKIFM199-INF1.KSHAD_CD			マンションオーナー情報作成.契約者住所コード
	 *			 TXT-KKIFM199-INF1.KSHAD_CD			マンションオーナー情報作成.契約者住所コード
	 *			 TXT-KKIFM199-INF1.KSHAD_CD			マンションオーナー情報作成.契約者住所コード
	 *			 TXT-KKIFM199-INF1.KSHAD_BNCHIGO			マンションオーナー情報作成.契約者住所＿番地号
	 *			 TXT-KKIFM199-INF1.KSHAD_BNCHIGO			マンションオーナー情報作成.契約者住所＿番地号
	 *			 TXT-KKIFM199-INF1.KSHAD_BNCHIGO			マンションオーナー情報作成.契約者住所＿番地号
	 *			 TXT-KKIFM199-INF1.KSH_RRKS			マンションオーナー情報作成.契約者連絡先
	 *			 TXT-KKIFM199-INF1.KSH_RRKS			マンションオーナー情報作成.契約者連絡先
	 *			 TXT-KKIFM199-INF1.KSH_RRKS			マンションオーナー情報作成.契約者連絡先
	 *			 TXT-KKIFM199-INF1.PID_BKN_NM_KN			マンションオーナー情報作成.Ｐ−ＩＤ物件名（カナ）
	 *			 TXT-KKIFM199-INF1.PID_BKN_NM_KN			マンションオーナー情報作成.Ｐ−ＩＤ物件名（カナ）
	 *			 TXT-KKIFM199-INF1.PID_BKN_NM			マンションオーナー情報作成.Ｐ−ＩＤ物件名
	 *			 TXT-KKIFM199-INF1.PID_BKN_NM			マンションオーナー情報作成.Ｐ−ＩＤ物件名
	 *			 TXT-KKIFM199-INF1.PID_BKN_AD_CD			マンションオーナー情報作成.Ｐ−ＩＤ物件住所コード
	 *			 TXT-KKIFM199-INF1.PID_BKN_AD_CD			マンションオーナー情報作成.Ｐ−ＩＤ物件住所コード
	 *			 TXT-KKIFM199-INF1.PID_BKN_AD_CD			マンションオーナー情報作成.Ｐ−ＩＤ物件住所コード
	 *			 TXT-KKIFM199-INF1.PID_BKN_AD_BNCHIGO			マンションオーナー情報作成.Ｐ−ＩＤ物件住所＿番地号
	 *			 TXT-KKIFM199-INF1.PID_BKN_AD_BNCHIGO			マンションオーナー情報作成.Ｐ−ＩＤ物件住所＿番地号
	 *			 TXT-KKIFM199-INF1.PID_BKN_AD_BNCHIGO			マンションオーナー情報作成.Ｐ−ＩＤ物件住所＿番地号
	 *			 TXT-KKIFM199-INF1.PID_TTL_TOU_CNT			マンションオーナー情報作成.Ｐ−ＩＤ総棟数
	 *			 TXT-KKIFM199-INF1.PID_TTL_TOU_CNT			マンションオーナー情報作成.Ｐ−ＩＤ総棟数
	 *			 TXT-KKIFM199-INF1.PID_TTL_TOU_CNT			マンションオーナー情報作成.Ｐ−ＩＤ総棟数
	 *			 TXT-KKIFM199-INF1.PID_TTL_KOSU			マンションオーナー情報作成.Ｐ−ＩＤ総戸数
	 *			 TXT-KKIFM199-INF1.PID_TTL_KOSU			マンションオーナー情報作成.Ｐ−ＩＤ総戸数
	 *			 TXT-KKIFM199-INF1.PID_TTL_KOSU			マンションオーナー情報作成.Ｐ−ＩＤ総戸数
	 *			 TXT-KKIFM199-INF1.KPCOFC_CD			マンションオーナー情報作成.関電営業所コード
	 *			 TXT-KKIFM199-INF1.KPCOFC_CD			マンションオーナー情報作成.関電営業所コード
	 *			 TXT-KKIFM199-INF1.KPCOFC_CD			マンションオーナー情報作成.関電営業所コード
	 * </pre>
	 * <p>
	 * @param rsMap 入力データ（TXT又はDB）を格納されたHashMap。
	 * @param itemvalueMap エラーメッセージに関する項目値を格納されたHashMap。
	 * @return  boolean trueである場合、エラーがありません。falseである場合、エラーを発生しました。
	 */
	private boolean isSingleCheckKKIFM199_INF1(HashMap rsMap, HashMap itemvalueMap)
	{
		// 単項目チェックを行います
		String strValue = null;
		String row = String.valueOf(commonItem.getInputCount());	//行数取得
		String pid = (String)rsMap.get("P-ID");	//PID
		boolean rslt = true;
		// 処理区分項目チェック
		strValue = (String)rsMap.get("TRAN_DIV");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			outErrLog(1, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.TRAN_DIV"));
			rslt = false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "1"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.TRAN_DIV"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakusuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.TRAN_DIV"));
  			rslt = false;
		}

		// Ｐ−ＩＤ項目チェック
		strValue = (String)rsMap.get("P-ID");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			outErrLog(1, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.P-ID"));
  			rslt = false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "10"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.P-ID"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.P-ID"));
  			rslt = false;
		}

		// Ｐ−ＩＤ登録年月日項目チェック
		strValue = (String)rsMap.get("PID_ADD_YMD");
		// 必須チェック
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "8"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.PID_ADD_YMD"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"year_month_day1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.PID_ADD_YMD"));
  			rslt = false;
		}

		// ビジネスシートタイプ項目チェック
		strValue = (String)rsMap.get("BUSINESS_SHT_TYPE");
		// 必須チェック
		if(strValue == null || "".equals(strValue))
		{
			outErrLog(1, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.BUSINESS_SHT_TYPE"));
  			rslt = false;
		}
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "5"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.BUSINESS_SHT_TYPE"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.BUSINESS_SHT_TYPE"));
  			rslt = false;
		}

		// 管理体系コード項目チェック
		strValue = (String)rsMap.get("KNRI_TIKI_CD");
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "3"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.KNRI_TIKI_CD"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.KNRI_TIKI_CD"));
  			rslt = false;
		}

		// 契約者名（カナ）項目チェック
		strValue = (String)rsMap.get("KSH_NM_KN");
		// 必須チェック
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"kisyuizon_nmad"}))//機種依存ok
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.KSH_NM_KN"));
  			rslt = false;
		}

		// 契約者名項目チェック
		strValue = (String)rsMap.get("KSH_NM");
		// 必須チェック
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"kisyuizon_nmad"}))//機種依存ok
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.KSH_NM"));
  			rslt = false;
		}

		// 契約者住所コード項目チェック
		strValue = (String)rsMap.get("KSHAD_CD");
		// 必須チェック
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "11"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.KSHAD_CD"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.KSHAD_CD"));
  			rslt = false;
		}

		// 契約者住所＿番地号項目チェック
		strValue = (String)rsMap.get("KSHAD_BNCHIGO");
		// 必須チェック
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "61"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.KSHAD_BNCHIGO"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"name_address"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.KSHAD_BNCHIGO"));
  			rslt = false;
		}

		// 契約者連絡先項目チェック
		strValue = (String)rsMap.get("KSH_RRKS");
		// 必須チェック
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"mix1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.KSH_RRKS"));
  			rslt = false;
		}

		// Ｐ−ＩＤ物件名（カナ）項目チェック
		strValue = (String)rsMap.get("PID_BKN_NM_KN");
		// 必須チェック
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"kisyuizon_nmad"}))//機種依存ok
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.PID_BKN_NM_KN"));
  			rslt = false;
		}

		// Ｐ−ＩＤ物件名項目チェック
		strValue = (String)rsMap.get("PID_BKN_NM");
		// 必須チェック
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"kisyuizon_nmad"}))//機種依存ok
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.PID_BKN_NM"));
  			rslt = false;
		}

		// Ｐ−ＩＤ物件住所コード項目チェック
		strValue = (String)rsMap.get("PID_BKN_AD_CD");
		// 必須チェック
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "11"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.PID_BKN_AD_CD"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.PID_BKN_AD_CD"));
  			rslt = false;
		}

		// Ｐ−ＩＤ物件住所＿番地号項目チェック
		strValue = (String)rsMap.get("PID_BKN_AD_BNCHIGO");
		// 必須チェック
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "61"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.PID_BKN_AD_BNCHIGO"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"name_address"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.PID_BKN_AD_BNCHIGO"));
  			rslt = false;
		}

		// Ｐ−ＩＤ総棟数項目チェック
		strValue = (String)rsMap.get("PID_TTL_TOU_CNT");
		// 必須チェック
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "12"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.PID_TTL_TOU_CNT"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakusuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.PID_TTL_TOU_CNT"));
  			rslt = false;
		}

		// Ｐ−ＩＤ総戸数項目チェック
		strValue = (String)rsMap.get("PID_TTL_KOSU");
		// 必須チェック
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "12"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.PID_TTL_KOSU"));
  			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakusuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.PID_TTL_KOSU"));
  			rslt = false;
		}

		// 関電営業所コード項目チェック
		strValue = (String)rsMap.get("KPCOFC_CD");
		// 必須チェック
		// 桁数チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"ketasuu2", "0", "3"}))
		{
			outErrLog(2, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.KPCOFC_CD"));
			rslt = false;
		}
		// 属性チェック
		if(!JBSbatCheckUtil.invoke(strValue, new String[]{"hannkakuesuuji1"}))
		{
			outErrLog(3, row, pid + " " + (String)itemvalueMap.get("TXT-KKIFM199-INF1.KPCOFC_CD"));
			rslt = false;
		}

		return rslt;
	}

	/**
	 * エラーメッセージに関する項目値を格納されたHashMap<String, String>を生成します。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.エラーメッセージに関する項目値を格納されたHashMapを生成する。<br>
	 *
	 * 2.エラーメッセージに関する項目値を格納されたHashMapに値を設定する。<br>
	 * </pre>
	 * <p>
	 * @return itemvalueMap エラーメッセージに関する項目値を格納されたHashMap
	 */
	private HashMap<String, String> getItemvalueMap()
	{
		// エラーメッセージに関する項目値が格納されたHashMapを設定
		HashMap<String, String> itemvalueMap = new HashMap<String, String>();
		itemvalueMap.put("TXT-KKIFM199-INF1.TRAN_DIV", "処理区分");
		itemvalueMap.put("TXT-KKIFM199-INF1.P-ID", "Ｐ−ＩＤ");
		itemvalueMap.put("TXT-KKIFM199-INF1.PID_ADD_YMD", "Ｐ−ＩＤ登録年月日");
		itemvalueMap.put("TXT-KKIFM199-INF1.BUSINESS_SHT_TYPE", "ビジネスシートタイプ");
		itemvalueMap.put("TXT-KKIFM199-INF1.KNRI_TIKI_CD", "管理体系コード");
		itemvalueMap.put("TXT-KKIFM199-INF1.KSH_NM_KN", "契約者名(カナ)");
		itemvalueMap.put("TXT-KKIFM199-INF1.KSH_NM", "契約者名");
		itemvalueMap.put("TXT-KKIFM199-INF1.KSHAD_CD", "契約者住所コード");
		itemvalueMap.put("TXT-KKIFM199-INF1.KSHAD_BNCHIGO", "契約者住所＿番地号");
		itemvalueMap.put("TXT-KKIFM199-INF1.KSH_RRKS", "契約者連絡先");

		itemvalueMap.put("TXT-KKIFM199-INF1.PID_BKN_NM_KN", "Ｐ−ＩＤ物件名（カナ）");
		itemvalueMap.put("TXT-KKIFM199-INF1.PID_BKN_NM", "Ｐ−ＩＤ物件名");
		itemvalueMap.put("TXT-KKIFM199-INF1.PID_BKN_AD_CD", "Ｐ−ＩＤ物件住所コード");
		itemvalueMap.put("TXT-KKIFM199-INF1.PID_BKN_AD_BNCHIGO", "Ｐ−ＩＤ物件住所＿番地号");
		itemvalueMap.put("TXT-KKIFM199-INF1.PID_TTL_TOU_CNT", "Ｐ−ＩＤ総棟数");
		itemvalueMap.put("TXT-KKIFM199-INF1.PID_TTL_KOSU", "Ｐ−ＩＤ総戸数");
		itemvalueMap.put("TXT-KKIFM199-INF1.PID_MEMO", "Ｐ−ＩＤメモ");
		itemvalueMap.put("TXT-KKIFM199-INF1.PID_KEI_RELATIN_TKJK", "Ｐ−ＩＤ契約関係特記事項");
		itemvalueMap.put("TXT-KKIFM199-INF1.PID_DLRE", "Ｐ−ＩＤ解約理由");
		itemvalueMap.put("TXT-KKIFM199-INF1.KPCOFC_CD", "関電営業所コード");

		return itemvalueMap;
	}
	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	/**
	 * SQLKEY(KK_SELECT_001)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	マンションオーナーID
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeKK_T_MANSION_BUKKEN_KK_SELECT_001(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());

		// DBアクセスを実行します
		db_KK_T_MANSION_BUKKEN.selectBySqlDefine(paramList, KK_T_MANSION_BUKKEN_KK_SELECT_001);
	}

	/**
	 * SQLKEY(KK_SELECT_001)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	マンションオーナーID
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeCK_T_MANSION_OWNR_KK_SELECT_001(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());

		// DBアクセスを実行します
		db_CK_T_MANSION_OWNR.selectBySqlDefine(paramList, CK_T_MANSION_OWNR_KK_SELECT_001);
	}

	/**
	 * SQLKEY(KK_SELECT_003)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	コード種別コード
	 *		 	コード区分
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeZM_M_CD_NM_KANRI_KK_SELECT_003(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());
		paramList.setValue(param[1].toString());

		// DBアクセスを実行します
		db_ZM_M_CD_NM_KANRI.selectBySqlDefine(paramList, ZM_M_CD_NM_KANRI_KK_SELECT_003);
	}

	/**
	 * SQLKEY(KK_SELECT_005)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	住所コード
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeZM_M_AD_KK_SELECT_005(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());

		// DBアクセスを実行します
		db_ZM_M_AD.selectBySqlDefine(paramList, ZM_M_AD_KK_SELECT_005);
	}
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/

	/**
	 * 処理区分の整合性チェック
	 * @param inMap
	 * @return 判定結果
	 * @throws Exception
	 */
	private boolean checkExist(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		if("1".equals(inMap.getString(JBSbatKKIFM199.TRAN_DIV)))
		{
			if(checkMansionBukkenCnt(inMap))
			{
				return existError(inMap, "マンション物件");
			}
			if(checkMansionOwnrCnt(inMap))
			{
				return existError(inMap, "マンションオーナー");
			}
		}
		else if("2".equals(inMap.getString(JBSbatKKIFM199.TRAN_DIV)))
		{
			if(!checkMansionBukkenCnt(inMap))
			{
				return notFoundError(inMap, "マンション物件");
			}
			if(!checkMansionOwnrCnt(inMap))
			{
				return notFoundError(inMap, "マンションオーナー");
			}
		}
		else if("3".equals(inMap.getString(JBSbatKKIFM199.TRAN_DIV)))
		{
			if(!checkMansionBukkenCnt(inMap))
			{
				return notFoundError(inMap, "マンション物件");
			}
			if(!checkMansionOwnrCnt(inMap))
			{
				return notFoundError(inMap, "マンションオーナー");
			}
			//サービス契約データがあれば削除不可
			if(checkOwnrKeiDlt(inMap))
			{
				commonItem.getLogPrint().printDebugLog("運用年月日:" + opeDate);
				return existError(inMap, "サービス契約");
			}
		}
		return true;
	}

	/**
	 * マンション物件件数検索
	 * @param inMap
	 * @return 判定結果
	 * @throws Exception
	 */
	private boolean checkMansionBukkenCnt(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		String[] param = {inMap.getString(JBSbatKKIFM199.PID)};
		executeKK_T_MANSION_BUKKEN_KK_SELECT_001(param);

		JBSbatCommonDBInterface dataMap = db_KK_T_MANSION_BUKKEN.selectNext();

		if(null == dataMap|| 1 > Integer.parseInt(dataMap.getString("CNT")))
		{
			return false;
		}
		return true;
	}

	/**
	 * マンションオーナー件数検索
	 * @param inMap
	 * @return 判定結果
	 * @throws Exception
	 */
	private boolean checkMansionOwnrCnt(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		String[] param = {inMap.getString(JBSbatKKIFM199.PID)};
		executeCK_T_MANSION_OWNR_KK_SELECT_001(param);

		JBSbatCommonDBInterface dataMap = db_CK_T_MANSION_OWNR.selectNext();

		if(null == dataMap|| 1 > Integer.parseInt(dataMap.getString("CNT")))
		{
			return false;
		}
		return true;
	}

	/**
	 * オーナー契約 検索(オ−ナー：削除前)
	 * @param inMap
	 * @return 判定結果
	 * @throws Exception
	 */
	private boolean checkOwnrKeiDlt(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		String[] param1 = {inMap.getString(JBSbatKKIFM199.PID)};
		executeKK_T_OWNR_KEI_KK_SELECT_007(param1);

		JBSbatCommonDBInterface dataMap1 = db_KK_T_OWNR_KEI.selectNext();
		//子契約があれば削除不可
		if(null == dataMap1 || 1 > Integer.parseInt(dataMap1.getString("CNT")))
		{
			String[] param2  = {inMap.getString(JBSbatKKIFM199.PID), opeDate};
			executeKK_T_OWNR_KEI_KK_SELECT_009(param2);

			JBSbatCommonDBInterface dataMap2 = db_KK_T_OWNR_KEI.selectNext();
			//１件でもあれば削除不可(サービス開始後)
			if(null == dataMap2 || 1 > Integer.parseInt(dataMap2.getString("CNT")))
			{
				return false;
			}
			commonItem.getLogPrint().printDebugLog("開始件数:" + dataMap2.getString("CNT"));
		}
		commonItem.getLogPrint().printDebugLog("契約件数:" + dataMap1.getString("CNT"));
		return true;
	}

	/**
	 * SQLKEY(KK_SELECT_007)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	P-ID
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeKK_T_OWNR_KEI_KK_SELECT_007(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());
		// DBアクセスを実行します
		db_KK_T_OWNR_KEI.selectBySqlDefine(paramList, KK_T_OWNR_KEI_KK_SELECT_007);
	}

	/**
	 * SQLKEY(KK_SELECT_009)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	P-ID
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeKK_T_OWNR_KEI_KK_SELECT_009(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());
		paramList.setValue(param[1].toString());
		// DBアクセスを実行します
		db_KK_T_OWNR_KEI.selectBySqlDefine(paramList, KK_T_OWNR_KEI_KK_SELECT_009);
	}

	/**
	 * 相関チェック
	 * @param inMap
	 * @return 判定結果
	 * @throws Exception
	 */
	private boolean checkCorrelation(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		//5桁から3桁にして対応 0705
		if(!checkCdNmKnrCnt("CD01228", inMap.getString(JBSbatKKIFM199.BUSINESS_SHT_TYPE).substring(2,5)))
		{
			return false;
		}
		String pid = inMap.getString(JBSbatKKIFM199.PID);
		if(!checkAdrsCnt(inMap.getString(JBSbatKKIFM199.KSHAD_CD), pid))
		{
			return false;
		}
		if(!checkAdrsCnt(inMap.getString(JBSbatKKIFM199.PID_BKN_AD_CD), pid))
		{
			return false;
		}
		return true;
	}
	
	//コード名称管理 件数検索
	private boolean checkCdNmKnrCnt(String cdSbt, String cdDiv) throws Exception
	{
		String[] param = {cdSbt, cdDiv};
		executeZM_M_CD_NM_KANRI_KK_SELECT_003(param);

		JBSbatCommonDBInterface dataMap = db_ZM_M_CD_NM_KANRI.selectNext();

		if( null == dataMap|| 1 > Integer.parseInt(dataMap.getString("CNT")))
		{
			commonItem.getLogPrint().printDebugLog("コード名称管理に存在しません。" + 
					"コード種別コード:" + cdSbt + " コード区分:" + cdDiv);
			return false;
		}
		return true;
	}

	/**
	 * 住所マスタ 件数検索
	 * @param addCd
	 * @param pid
	 * @return 判定結果
	 * @throws Exception
	 */
	private boolean checkAdrsCnt(String addCd, String pid) throws Exception
	{
		//なければ検索しない
		if("".equals(addCd))
		{
			return true;
		}
		String[] param = {addCd};
		executeZM_M_AD_KK_SELECT_005(param);

		JBSbatCommonDBInterface dataMap = db_ZM_M_AD.selectNext();

		if(null == dataMap|| 1 > Integer.parseInt(dataMap.getString("CNT")))
		{
			//%1%テーブルに%2%が存在しません。（key：%3%）
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0630NW", 
					new String[]{"住所マスタ", "住所コード:" + addCd, "P-ID:" + pid});
			return false;
		}
		return true;
	}

	/**
	 * ファイル情報をセット
	 * @param inMap
	 * @return 出力ファイル情報
	 * @throws Exception
	 */
	private JBSbatServiceInterfaceMap setRcvInfo(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		JBSbatServiceInterfaceMap outMap = new JBSbatServiceInterfaceMap();

		outMap.set(JBSbatKKIFM199.TRAN_DIV, inMap.getString(JBSbatKKIFM199.TRAN_DIV));
		outMap.set(JBSbatKKIFM199.PID, inMap.getString(JBSbatKKIFM199.PID));
		outMap.set(JBSbatKKIFM199.PID_ADD_YMD, inMap.getString(JBSbatKKIFM199.PID_ADD_YMD));
		outMap.set(JBSbatKKIFM199.BUSINESS_SHT_TYPE, inMap.getString(JBSbatKKIFM199.BUSINESS_SHT_TYPE));
		outMap.set(JBSbatKKIFM199.KNRI_TIKI_CD, inMap.getString(JBSbatKKIFM199.KNRI_TIKI_CD));
		outMap.set(JBSbatKKIFM199.KSH_NM_KN, subStringTrgt(45, inMap.getString(JBSbatKKIFM199.KSH_NM_KN)));
		outMap.set(JBSbatKKIFM199.KSH_NM, subStringTrgt(45, inMap.getString(JBSbatKKIFM199.KSH_NM)));
		outMap.set(JBSbatKKIFM199.KSHAD_CD, inMap.getString(JBSbatKKIFM199.KSHAD_CD));
		outMap.set(JBSbatKKIFM199.KSHAD_BNCHIGO, inMap.getString(JBSbatKKIFM199.KSHAD_BNCHIGO));
		outMap.set(JBSbatKKIFM199.KSH_RRKS, subStringTrgt(2000, inMap.getString(JBSbatKKIFM199.KSH_RRKS)));

		outMap.set(JBSbatKKIFM199.PID_BKN_NM_KN, subStringTrgt(45, inMap.getString(JBSbatKKIFM199.PID_BKN_NM_KN)));
		outMap.set(JBSbatKKIFM199.PID_BKN_NM, subStringTrgt(45, inMap.getString(JBSbatKKIFM199.PID_BKN_NM)));
		outMap.set(JBSbatKKIFM199.PID_BKN_AD_CD, inMap.getString(JBSbatKKIFM199.PID_BKN_AD_CD));
		outMap.set(JBSbatKKIFM199.PID_BKN_AD_BNCHIGO, inMap.getString(JBSbatKKIFM199.PID_BKN_AD_BNCHIGO));
		outMap.set(JBSbatKKIFM199.PID_TTL_TOU_CNT, inMap.getString(JBSbatKKIFM199.PID_TTL_TOU_CNT));
		outMap.set(JBSbatKKIFM199.PID_TTL_KOSU, inMap.getString(JBSbatKKIFM199.PID_TTL_KOSU));
		outMap.set(JBSbatKKIFM199.PID_MEMO, subStringTrgt(2000, inMap.getString(JBSbatKKIFM199.PID_MEMO)));
		outMap.set(JBSbatKKIFM199.PID_KEI_RELATIN_TKJK, 
				subStringTrgt(2000, inMap.getString(JBSbatKKIFM199.PID_KEI_RELATIN_TKJK)));
		outMap.set(JBSbatKKIFM199.PID_DLRE, subStringTrgt(2000, inMap.getString(JBSbatKKIFM199.PID_DLRE)));
		outMap.set(JBSbatKKIFM199.KPCOFC_CD, inMap.getString(JBSbatKKIFM199.KPCOFC_CD));

		outMap.setOutFlg(true);
		return outMap;
	}

	/**
	 * 指定文字数以上の場合、切り捨てる
	 * @param length
	 * @param target
	 * @return 編集後文字列
	 */
	private String subStringTrgt(int length, String target) {
		String rslt = target;

		if(null == target)
		{
			return rslt;
		}

		if(length < target.length())
		{
			rslt = target.substring(0, length);
		}
		return rslt;
	}

	/**
	 * 不整合エラーログ出力
	 * @param inMap
	 * @param tblNm
	 * @return false
	 * @throws Exception
	 */
	private boolean existError(JBSbatServiceInterfaceMap inMap, String tblNm) throws Exception
	{
		//処理区分の値とDBの内容に不整合があります。（テーブル名：%1%　行数：%2%　key：%3%）
		commonItem.getLogPrint().printBusinessErrorLog("EKKB0570NW", 
				new String[]{tblNm, String.valueOf(commonItem.getInputCount()), 
				"P-ID:" + inMap.getString(JBSbatKKIFM199.PID) +
				" 処理区分:" + inMap.getString(JBSbatKKIFM199.TRAN_DIV)});
		return false;
	}

	/**
	 * エラーログ出力
	 * @param inMap
	 * @param tblNm
	 * @return false
	 * @throws Exception
	 */
	private boolean notFoundError(JBSbatServiceInterfaceMap inMap, String tblNm) throws Exception
	{
		//%1%テーブルに%2%が存在しません。
		String pid = inMap.getString(JBSbatKKIFM199.PID);
		commonItem.getLogPrint().printBusinessErrorLog("EKKB0630NW", 
				new String[]{tblNm, pid, "P-ID:" + pid});
		return false;
	}

	/**
	 * 入力データ単項目エラーログ出力
	 * @param mode
	 * @param row
	 * @param key
	 */
	private void outErrLog(int mode, String row, String key)
	{
		String[] err = new String[]{row, "P-ID:" + key};
		if(1 == mode)//必須
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0580TW", err);
		}
		else if(2 == mode)//桁数
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0590TW", err);
		}else if(3 == mode)//属性
		{
			commonItem.getLogPrint().printBusinessErrorLog("EKKB0600TW", err);
		}
	}
}
