/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatKUGenesisOldEquipDelCst
*	ソースファイル名	：JBSbatKUGenesisOldEquipDelCst.java
*	作成者				：富士通　
*	作成日				：2011年08月24日
*＜機能概要＞
*　Ｇｅｎｅｓｉｓ旧設備削除情報抽出部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/08/24   富士通		新規作成
*	v9.00.00	2014/09/25   FJ)阪口	【OM-2014-0003165】FCDS／Genesisへの設備削除情報連携不備
*   v37.00.00   2018/02/26   FJ)岩本    【ANK-3366-00-00】eo光設備卸対応
*  	v51.00.00	2020/08/26	 GDC)ミコ	【ANK-3885-00-00】光化マンションの自動設計対応
*	v56.00.00	2021/09/17   GDC)オーヴィー	【ANK-4038-00-00】光ローゼット化対応
*	v56.00.01	2021/12/01   FJ)謝		【IT1-2021-0000095】対応
*   v60.00.00	2022/06/16	 FJ)Arah	【ANK-4244-00-00】【eo定期】MT既設賃貸対応
*   v60.00.00	2022/07/01	 FJ)アら	【ANK-4269-00-00】マンション卸回線(WI-FIスキーム)の不備対応　STEP2
*	v62.00.00	2022/11/01	 FJ)アラ    【ANK-4285-00-00】【eo】ローゼット化対応フォロー案件２
*	v61.00.00	2023/10/03   FJ)佐野	【ANK-4315-00-00】【eo定期】 eoホームゲートウェイ導入対応
*	v69.00.00	2024/01/28   FJ)永瀬    【#83597】旧設備削除が連携された
*	v69.00.01	2024/03/13   FJ)永瀬    【#84267】返品受入登録で異常終了
*   v73.00.00	2024/10/30	 FJ)橋本	【ANK-4493-00-00】【eo定期】 光配線マンションのコースアップ対応
*********************************************************************/
package eo.business.service;

import java.util.HashMap;

import eo.business.common.JBSbatBusinessService;
import eo.business.common.JKUBatCommon;
import eo.business.util.file.JBSbatKUIFE023;
import eo.business.util.table.JBSbatCK_T_CUST;
import eo.business.util.table.JBSbatKU_T_KJAK_EOH_NTMANS;
import eo.business.util.table.JBSbatKU_T_KOJIAK;
import eo.business.util.table.JBSbatKU_T_SENKO_DSGN;
import eo.common.constant.JKUStrConst;
import eo.common.constant.JPCBatchMessageConstant;
import eo.framework.application.JBSbatBusinessError;
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 static eo.common.util.JDKCommonUtil.isNull;

/**
* Ｇｅｎｅｓｉｓ旧設備削除情報抽出部品です。 <p>
*<BR>
* @author 富士通
*/
public class JBSbatKUGenesisOldEquipDelCst extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/** テーブル(工事案件ＰＫ検索)*/
	private static final String D_TBL_NAME_KU_T_KOJIAK = "KU_T_KOJIAK";

	/** テーブル(先行設計)*/
	private static final String D_TBL_NAME_KU_T_SENKO_DSGN = "KU_T_SENKO_DSGN";

// ANK-3366-00-00 ADD START
	/** テーブル(お客様)*/
	private static final String D_TBL_NAME_CK_T_CUST = "CK_T_CUST";
	
	/** SQL定義キー(KU_SELECT_001)*/
	private static final String CK_T_CUST_KU_SELECT_001 = "KU_SELECT_001";
// ANK-3366-00-00 ADD END
	
	/** SQL定義キー(KU_SELECT_004)*/
	private static final String KU_T_SENKO_DSGN_KU_SELECT_004 = "KU_SELECT_004";

	/** テーブルアクセスクラス(工事案件ＰＫ検索)*/
	private JBSbatSQLAccess db_KU_T_KOJIAK = null;

	/** テーブルアクセスクラス(先行設計)*/
	private JBSbatSQLAccess db_KU_T_SENKO_DSGN = null;
	
// ANK-3366-00-00 ADD START
	/** テーブルアクセスクラス(お客様)*/
	private JBSbatSQLAccess db_CK_T_CUST = null;
// ANK-3366-00-00 ADD END
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/
	
	/**▼▼▼▼▼▼業務チームで作成した宣言です 開始▼▼▼▼▼▼*/
	
	/** テーブル(工事案件＜光ネットマンション＞)*/	
	private static final String D_TBL_NAME_KU_T_KJAK_EOH_NTMANS = "KU_T_KJAK_EOH_NTMANS";
	/** テーブル(局番)*/
	private static final String D_TBL_NAME_ZM_M_KYOKU_NO = "ZM_M_KYOKU_NO";

	// ANK-4038-00-00 ADD START
	/** 工事範囲コードが"069"(切断ツール利用)*/
	private static final String KOJI_SCOPE_CD_CUT_TOOL_USE = "069";

	/** 工事範囲コードが"070"(ローゼット済工事不要案件)*/
	private static final String KOJI_SCOPE_CD_RZT_ZM_KJ_FYO_ANK = "070";
	// ANK-4038-00-00 ADD END
	
	/** テーブルアクセスクラス(工事案件＜光ネットマンション＞) */
	private JBSbatSQLAccess dKuTKjakEohNtMans = null;
	/** テーブルアクセスクラス(番ポ可能エリア対象局番)*/
	private JBSbatSQLAccess db_ZM_M_KYOKU_NO = null;
	
	/**▲▲▲▲▲▲業務チームで作成した宣言です 終了▲▲▲▲▲▲*/

	/**▼▼▼▼▼▼業務チームで作成した宣言です 開始▼▼▼▼▼▼*/
	/** 旧設備削除情報抽出経過日数*/
	private String ku_OLDEQUIP_CST_DAYS = null;
	//#84267 DEL STAR
	////#83597 ADD START
	///** 旧設備削除連携済 */
	//private static final String KU_OLDEQUIP_SUMI = "3";
	////#83597 ADD END
	//#84267 DEL END
	//#84267 ADD START
	/** 工事完了連携済 */
	private static final String KOJI_KANRYO = "2";
	//#84267 ADD END
	
	/**▲▲▲▲▲▲業務チームで作成した宣言です 終了▲▲▲▲▲▲*/

	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);

		// DBアクセスクラスを生成します
		db_KU_T_KOJIAK = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KU_T_KOJIAK);
		db_KU_T_SENKO_DSGN = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KU_T_SENKO_DSGN);
// ANK-3366-00-00 ADD START
		db_CK_T_CUST = new JBSbatSQLAccess(commonItem, D_TBL_NAME_CK_T_CUST);
// ANK-3366-00-00 ADD END
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/

		dKuTKjakEohNtMans = new JBSbatSQLAccess(commonItem, D_TBL_NAME_KU_T_KJAK_EOH_NTMANS);
		db_ZM_M_KYOKU_NO = new JBSbatSQLAccess(commonItem, D_TBL_NAME_ZM_M_KYOKU_NO);
		
		// 業務パラメータ　旧設備削除情報抽出経過日数　取得
		ku_OLDEQUIP_CST_DAYS = new JKUBatCommon().getWorkParamKnri(commonItem, JKUStrConst.KU_OLDEQUIP_CST_DAYS);

		if (null == ku_OLDEQUIP_CST_DAYS)
		{
			// 取得できなかった場合は、ログ出力し、処理終了
			throw new JBSbatBusinessException(JPCBatchMessageConstant.EKUB0070KE, new String[]{
					JKUStrConst.SCHEMANM_ZM0321,
					"業務パラメータID",
					JKUStrConst.KU_OLDEQUIP_CST_DAYS});
		}
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @param inMap　入力電文
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute(JBSbatServiceInterfaceMap inMap) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		// 出力共通電文を生成する。
		JBSbatOutputItem outputBean = new JBSbatOutputItem();
		
		// 入出力インターフェースオブジェクトを生成
		JBSbatServiceInterfaceMap outMap = null;
		
		// 工事案件番号
		String kojiakNo = inMap.getString(JBSbatKU_T_KOJIAK.KOJIAK_NO);
		
		// 工事案件ＰＫ検索
		JBSbatCommonDBInterface ku0011Map = this.findKU_T_KOJIAK(kojiakNo);
		
		// 工事案件が存在しない場合、次レコードへ
		if (null == ku0011Map)
		{
			
			// ログ出力し、次レコードへ
			super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.EKUB0650KW, new String[]{
					JKUStrConst.SCHEMANM_KU0011,
					"工事案件番号",
					kojiakNo});
			
			throw new JBSbatBusinessError();
		}
		
		// 更新対象工事案件番号
		String updTrgtKojiakNo = ku0011Map.getString(JBSbatKU_T_KOJIAK.UPD_TRGT_KOJIAK_NO);

// ANK-4285-00-00 ADD START
		// 工事案件ＰＫ検索
		JBSbatCommonDBInterface ku0011UpdTrgtMap = this.findKU_T_KOJIAK(updTrgtKojiakNo);
// ANK-4285-00-00 ADD END
		
		// 先行設計検索
		JBSbatCommonDBInterface senkouMap = this.findKU_T_SENKO(updTrgtKojiakNo);
		
		// 先行設計が存在しない場合、次レコードへ
		if (null == senkouMap)
		{
			// ログ出力し、次レコードへ
			super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.EKUB0650KW, new String[]{
					JKUStrConst.SCHEMANM_KU0101,
					"工事案件番号",
					updTrgtKojiakNo});
			
			throw new JBSbatBusinessError();
		}
		
// IT1-2021-0000095 ADD START
		// 工事範囲コード
		String kojiScopeCd = inMap.getString("KOJI_SCOPE_CD");
		
		// 工事範囲コードが"069"(切断ツール利用)、"070"(ローゼット済工事不要案件)の場合
		if (KOJI_SCOPE_CD_CUT_TOOL_USE.equals(kojiScopeCd) || KOJI_SCOPE_CD_RZT_ZM_KJ_FYO_ANK.equals(kojiScopeCd))
		{
			// 経過日数チェックしない
		}
		// 上記以外の場合
		else
		{
// IT1-2021-0000095 ADD END
			// 一定期間超過チェック
			if (!checkDateDiff(ku0011Map))
			{
				// 一定期間超過していないレコードは出力対象としない
				
				return null;
			}
// IT1-2021-0000095 ADD START
		}
// IT1-2021-0000095 ADD END

		// #83597 MOD START
		// 更新対象工事案件番号
		String updTrgtKojiakNo_1 = ku0011UpdTrgtMap.getString(JBSbatKU_T_KOJIAK.UPD_TRGT_KOJIAK_NO);
		
		//抽出された更新対象工事案件番号がnullではないの場合の処理
		if(!isNull(updTrgtKojiakNo_1) ){
			//1世代前レコードのＧｅｎｅｓｉｓ連携種別コードが7以外の場合2世代前の確認に入る
			if (!(JKUStrConst.CD00699_KOJI_FIN_RENKEIZM.equals(ku0011UpdTrgtMap.getString("GENESIS_RNKI_SBT_CD")) && (KOJI_SCOPE_CD_CUT_TOOL_USE.equals(kojiScopeCd) || KOJI_SCOPE_CD_RZT_ZM_KJ_FYO_ANK.equals(kojiScopeCd)))){
				// 更新対象工事案件番号
				String updTrgtKojiakNo_2 = ku0011UpdTrgtMap.getString(JBSbatKU_T_KOJIAK.UPD_TRGT_KOJIAK_NO);
				
				//抽出された更新対象工事案件番号がnullではないの場合の処理
				if(!isNull(updTrgtKojiakNo_2) ){
					// 検索処理に渡すパラメタを設定
					Object[] whereParam = new Object[1];
					
					whereParam[0] = updTrgtKojiakNo_2;
					
					//　更新対象工事案件番号で、2世代前の工事案件番号情報を取得する。
					JBSbatCommonDBInterface kojiakMap = this.executeKU_T_KOJIAK_PKSELECT(whereParam);
					
					//#84267MOD START
					////工事案件番号情報を取得した結果がnullではない場合、2世代前の連携種別を確認し3以外は処理をスキップ
					//工事案件番号情報を取得した結果がnullではない場合、2世代前の連携種別を確認し2の場合は処理をスキップ
					//#84267MOD END
					if(!isNull(kojiakMap)){
						//#84267MOD START
						//// 連携種別が「旧設備削除」以外の場合、アラームを発しreturnする。
						//if ( !kojiakMap.getString(JBSbatKU_T_KOJIAK.GENESIS_RNKI_SBT_CD).equals(KU_OLDEQUIP_SUMI)	)
						// 連携種別が「工事完了」の場合、アラームを発しreturnする。
						if ( KOJI_KANRYO.equals(kojiakMap.getString(JBSbatKU_T_KOJIAK.GENESIS_RNKI_SBT_CD))	)
						//#84267MOD END
						{
						
							// (d) エラーメッセージを出力し、処理を終了する。(マイナーアラームを通知する)
							super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.EDKB0780KW, new String[]{
									kojiakNo});
							
							// エラーフラグ設定
							super.commonItem.setErrorCount(1);
							
							return null;
						}
					}
					
				}
			}
		}
		// #83597 MOD END
		
// ANK-4285-00-00 MOD START	
//		// ANK-4038-00-00 MOD START
//		// 出力ファイルを編集
//		//outMap = this.setOutMap(ku0011Map, senkouMap);
//		outMap = this.setOutMap(ku0011Map, senkouMap, inMap);
//		// ANK-4038-00-00 MOD END
//		
//		if (null != outMap)
//		{
//			// 出力共通電文に入出力インターフェースを設定する。
//			outputBean.addOutMapList(outMap);
//			
//			// 工事案件を更新(※工事案件種別がプラン変更(収容替)の場合は実行しない)
//			if(!JKUStrConst.CD00577_PLAN_CHG_SHUYO.equals(ku0011Map.getString(JBSbatKU_T_KOJIAK.KOJIAK_SBT_CD)))
//			{
//				this.updateKU_T_KOJIAK(kojiakNo);
//			}
//			
//			// 更新対象工事案件を更新
//			this.updateKU_T_KOJIAK(updTrgtKojiakNo);
//		}
			// 出力ファイルを編集
			outMap = this.setOutMap(ku0011Map, senkouMap, inMap, ku0011UpdTrgtMap );
			
			if (null != outMap)
			{
				// 出力共通電文に入出力インターフェースを設定する。
				outputBean.addOutMapList(outMap);
			
			String genesisRnkSbtCd = ku0011UpdTrgtMap.getString(JBSbatKU_T_KOJIAK.GENESIS_RNKI_SBT_CD);
//ANK-4315-00-00 MOD START
//			// 工事案件を更新(※工事案件種別がプラン変更(収容替)の場合は実行しない)
//			if(!JKUStrConst.CD00577_PLAN_CHG_SHUYO.equals(ku0011Map.getString(JBSbatKU_T_KOJIAK.KOJIAK_SBT_CD)))
			// 工事案件を更新(※工事案件種別が「プラン変更(収容替)」、「ONU交換工事」の場合は実行しない)
			if(!JKUStrConst.CD00577_PLAN_CHG_SHUYO.equals(ku0011Map.getString(JBSbatKU_T_KOJIAK.KOJIAK_SBT_CD))&&!JKUStrConst.CD00577_ONU_KOKAN_KOJI.equals(ku0011Map.getString(JBSbatKU_T_KOJIAK.KOJIAK_SBT_CD)))
//ANK-4315-00-00 MOD END
			{
				this.updateKU_T_KOJIAK(kojiakNo, genesisRnkSbtCd, kojiScopeCd);
			}
			
			// 更新対象工事案件を更新
			this.updateKU_T_KOJIAK(updTrgtKojiakNo, genesisRnkSbtCd, kojiScopeCd);
		}
// ANK-4285-00-00 MOD END
		return outputBean;
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		// DBアクセスクラスをクローズします
		db_KU_T_KOJIAK.close();
		db_KU_T_SENKO_DSGN.close();
// ANK-3366-00-00 ADD START
		db_CK_T_CUST.close();
// ANK-3366-00-00 ADD END
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
		dKuTKjakEohNtMans.close();
		db_ZM_M_KYOKU_NO.close();
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	/**
	 * 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);
	}

	/**
	 * SQLKEY(KU_SELECT_004)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	工事案件番号
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeKU_T_SENKO_DSGN_KU_SELECT_004(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());

		// DBアクセスを実行します
		db_KU_T_SENKO_DSGN.selectBySqlDefine(paramList, KU_T_SENKO_DSGN_KU_SELECT_004);
	}

	/**
	 * PK(ＰＫ　更新)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数で設定項目マップを作ります。<br>
	 *
	 * 2.引数で条件マップを作ります。<br>
	 *
	 * 3.DBアクセスを実行します。<br>
	 * 
	 * 4.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		setParam:設定したい項目の(項目、値)を(key、value)として、setParamマップに入れます。項目キーは以下に説明します。
	 *		 	Ｇｅｎｅｓｉｓ連携種別コード				GENESIS_RNKI_SBT_CD
	 *		 	Ｇｅｎｅｓｉｓ連携種別変更年月日時分秒				GENESIS_RNKI_SBT_CHGE_DTM
	 *		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("GENESIS_RNKI_SBT_CD", setParam[0]);
		setMap.setValue("GENESIS_RNKI_SBT_CHGE_DTM", setParam[1]);
	
		// 条件のマップを作成します
		JBSbatCommonDBInterface whereMap = new JBSbatCommonDBInterface();
		whereMap.setValue("KOJIAK_NO", whereParam[0]);

		// DBアクセスを実行します
		db_KU_T_KOJIAK.updateByPrimaryKeys(whereMap, setMap);
	}
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/
	/**▼▼▼▼▼▼業務チームで作成したメソッドです 開始▼▼▼▼▼▼*/

// ANK-4285-00-00 MOD START
//// ANK-4038-00-00 MOD START
////	/**
////	 * 出力共通電文を設定します。
////	 * @param ku0011Map 入力電文
////	 * @param senkouMap 先行設計
////	 * @return 出力共通電文
////	 * @throws Exception
////	 */
////	private JBSbatServiceInterfaceMap setOutMap(JBSbatCommonDBInterface ku0011Map, JBSbatCommonDBInterface senkouMap) throws Exception
//	/**
//	 * 出力共通電文を設定します。
//	 * @param ku0011Map 入力電文
//	 * @param senkouMap 先行設計
//	 * @return 出力共通電文
//	 * @throws Exception
//	 */
//	private JBSbatServiceInterfaceMap setOutMap(JBSbatCommonDBInterface ku0011Map, JBSbatCommonDBInterface senkouMap, JBSbatServiceInterfaceMap inMap) throws Exception
////ANK-4038-00-00 MOD END	
	/**
	 * 出力共通電文を設定します。
	 * @param ku0011Map 入力電文
	 * @param senkouMap 先行設計
	 * @return 出力共通電文
	 * @param ku0011UpdTrgtMap 工事案件情報 
	 * @throws Exception
	 */
	private JBSbatServiceInterfaceMap setOutMap(JBSbatCommonDBInterface ku0011Map, JBSbatCommonDBInterface senkouMap, JBSbatServiceInterfaceMap inMap, JBSbatCommonDBInterface ku0011UpdTrgtMap) throws Exception
// ANK-4285-00-00 MOD END
	{
		// バッチ共通アクセッサー
		JKUBatCommon jKUBatCommon = new JKUBatCommon();
		
		// 出力電文
		JBSbatServiceInterfaceMap outMap = new JBSbatServiceInterfaceMap();
		
		// 出力フラグを設定
		outMap.setOutFlg(true);	

// ANK-3366-00-00 ADD START
		// 工事案件のSYSID
		String sysidParam  = ku0011Map.getString(JBSbatKU_T_KOJIAK.SYSID);
		
		// お客様取得処理を呼び出し、卸先事業者コードを取得する
		String orsjgsCd = findOrsjgsCd(sysidParam);
// ANK-3366-00-00 ADD END
		
		// 現在工程
		// ANK-4038-00-00 MOD START
		//outMap.setString(JBSbatKUIFE023.NOW_STEP, JKUStrConst.KEI_STAT_OLD_EQUIP_DEL);
		String kojiScopeCd = inMap.getString(JBSbatKU_T_KJAK_EOH_NTMANS.KOJI_SCOPE_CD);
		// 工事範囲コードが"069"(切断ツール利用)、"070"(ローゼット済工事不要案件)
		if (KOJI_SCOPE_CD_CUT_TOOL_USE.equals(kojiScopeCd) || KOJI_SCOPE_CD_RZT_ZM_KJ_FYO_ANK.equals(kojiScopeCd))
		{
// ANK-4285-00-00 MOD START
//			// 「96:工事スキップによる解約」を設定する
//			outMap.setString(JBSbatKUIFE023.NOW_STEP, JKUStrConst.KEI_STAT_KOJI_SKP_DSL);
			String genesisRnkSbtCd = ku0011UpdTrgtMap.getString(JBSbatKU_T_KOJIAK.GENESIS_RNKI_SBT_CD);
			
			if(JKUStrConst.CD00699_KOJI_FIN_RENKEIZM.equals(genesisRnkSbtCd)){
				// 「91:解約済」を設定する
				outMap.setString(JBSbatKUIFE023.NOW_STEP, JKUStrConst.KEI_STAT_DSL_SM);
			}
			else{
				// 「96:工事スキップによる解約」を設定する
				outMap.setString(JBSbatKUIFE023.NOW_STEP, JKUStrConst.KEI_STAT_KOJI_SKP_DSL);
			}
// ANK-4285-00-00 MOD START END
		}
		else // 上記以外
		{
			// 「94:旧設備削除」を設定する
			outMap.setString(JBSbatKUIFE023.NOW_STEP, JKUStrConst.KEI_STAT_OLD_EQUIP_DEL);
		}
		// ANK-4038-00-00 MOD END

		// 工事案件番号
		outMap.setString(JBSbatKUIFE023.KOJIAK_NO, ku0011Map.getString(JBSbatKU_T_KOJIAK.UPD_TRGT_KOJIAK_NO));

		// 電話番号種別
		outMap.setString(JBSbatKUIFE023.TELNO_SBT, null);

		// 回線場所電話番号分割
		String[] kaisenPlaceTelno = new String[3];
		kaisenPlaceTelno = jKUBatCommon.splitTln(commonItem, ku0011Map.getString(JBSbatKU_T_KOJIAK.CUST_HOME_TELNO), db_ZM_M_KYOKU_NO);

		if(null != kaisenPlaceTelno)
		{
			// 回線場所電話番号１
			outMap.setString(JBSbatKUIFE023.KAISEN_PLACE_TELNO_1, kaisenPlaceTelno[0]);
			
			// 回線場所電話番号２
			outMap.setString(JBSbatKUIFE023.KAISEN_PLACE_TELNO_2, kaisenPlaceTelno[1]);
			
			// 回線場所電話番号３
			outMap.setString(JBSbatKUIFE023.KAISEN_PLACE_TELNO_3, kaisenPlaceTelno[2]);
		}
		
		// お客様名１
		outMap.setString(JBSbatKUIFE023.CUST_NM_1, JKUBatCommon.getCustName1(ku0011Map.getString(JBSbatKU_T_KOJIAK.CUST_NM)));
		
		// お客様名２
		String[] custName2 = JKUBatCommon.splitString(JKUBatCommon.getCustName2(ku0011Map.getString(JBSbatKU_T_KOJIAK.CUST_NM)), 30, true);
		outMap.setString(JBSbatKUIFE023.CUST_NM_2, custName2[0]);

		// お客様カナ名
		String[] custKana = JKUBatCommon.splitString(ku0011Map.getString(JBSbatKU_T_KOJIAK.CUST_KANA), 30, true);
		outMap.setString(JBSbatKUIFE023.CUST_KANA, custKana[0]);

		// 連絡先電話番号種別
		outMap.setString(JBSbatKUIFE023.CUST_RRKS_TELNO_SBT_CD, null);

		// お客様連絡先電話番号分割
		String[] custRrksTelno = new String[3];
		custRrksTelno = jKUBatCommon.splitTln(commonItem, ku0011Map.getString(JBSbatKU_T_KOJIAK.CUST_RRKS_TELNO), db_ZM_M_KYOKU_NO);

		if(null != custRrksTelno)
		{
			// お客様連絡先電話番号１
			outMap.setString(JBSbatKUIFE023.CUST_RRKS_TELNO_1, custRrksTelno[0]);
			
			// お客様連絡先電話番号２
			outMap.setString(JBSbatKUIFE023.CUST_RRKS_TELNO_2, custRrksTelno[1]);
			
			// お客様連絡先電話番号３
			outMap.setString(JBSbatKUIFE023.CUST_RRKS_TELNO_3, custRrksTelno[2]);
		}
		
		// 備考
		outMap.setString(JBSbatKUIFE023.BIKO, null);

		// サービス契約番号
		outMap.setString(JBSbatKUIFE023.SVC_KEI_NO, ku0011Map.getString(JBSbatKU_T_KOJIAK.RNKI_SVC_KEI_NO));

		// 都道府県名
		outMap.setString(JBSbatKUIFE023.STATE_NM, ku0011Map.getString(JBSbatKU_T_KOJIAK.TENTAKU_SAKI_STATE_NM));

		// 市区町村名
		outMap.setString(JBSbatKUIFE023.CITY_NM, ku0011Map.getString(JBSbatKU_T_KOJIAK.TENTAKU_SAKI_CITY_NM));

		// 大字通称名
		outMap.setString(JBSbatKUIFE023.OAZTSU_NM, ku0011Map.getString(JBSbatKU_T_KOJIAK.TENTAKU_SAKI_OAZTSU_NM));

		// 字丁目名
		outMap.setString(JBSbatKUIFE023.AZCHO_NM, ku0011Map.getString(JBSbatKU_T_KOJIAK.TENTAKU_SAKI_AZCHO_NM));

		// 住所番地号
		outMap.setString(JBSbatKUIFE023.AD_BNCHIGO, ku0011Map.getString(JBSbatKU_T_KOJIAK.TENTAKU_SAKI_AD_BNCHIGO));

		// 住所補記・建物名
		outMap.setString(JBSbatKUIFE023.ADRTTM, ku0011Map.getString(JBSbatKU_T_KOJIAK.TENTAKU_SAKI_ADRTTM));

		// 住所補記・部屋番号
		outMap.setString(JBSbatKUIFE023.ADRRM, ku0011Map.getString(JBSbatKU_T_KOJIAK.TENTAKU_SAKI_ADRRM));

		// Ｘ座標（６系）
		outMap.setString(JBSbatKUIFE023.XZAHYO_6, ku0011Map.getString(JBSbatKU_T_KOJIAK.XZAHYO_6));

		// Ｙ座標（６系）
		outMap.setString(JBSbatKUIFE023.YZAHYO_6, ku0011Map.getString(JBSbatKU_T_KOJIAK.YZAHYO_6));

		// お客様連絡先携帯電話番号分割
		String[] custRrksktaitelno = new String[3];
		custRrksktaitelno = jKUBatCommon.splitTln(commonItem, ku0011Map.getString(JBSbatKU_T_KOJIAK.CUST_KTAI_TELNO), db_ZM_M_KYOKU_NO);

		if(null != custRrksktaitelno)
		{
			// お客様連絡先携帯電話番号１
			outMap.setString(JBSbatKUIFE023.CUST_RRKS_KTAI_TELNO_1, custRrksktaitelno[0]);
			
			// お客様連絡先携帯電話番号２
			outMap.setString(JBSbatKUIFE023.CUST_RRKS_KTAI_TELNO_2, custRrksktaitelno[1]);
			
			// お客様連絡先携帯電話番号３
			outMap.setString(JBSbatKUIFE023.CUST_RRKS_KTAI_TELNO_3, custRrksktaitelno[2]);
		}
		
		// 利用場所階数
		outMap.setString(JBSbatKUIFE023.USE_PLACE_KAISU, ku0011Map.getString(JBSbatKU_T_KOJIAK.KCKU_FLR_CNT_CD));

		// 工事案件完了年月日
		outMap.setString(JBSbatKUIFE023.KOJIAK_FIN_YMD, null);

		// Ｘ座標（５系）
		outMap.setString(JBSbatKUIFE023.XZAHYO_5, ku0011Map.getString(JBSbatKU_T_KOJIAK.XZAHYO_5));

		// Ｙ座標（５系）
		outMap.setString(JBSbatKUIFE023.YZAHYO_5, ku0011Map.getString(JBSbatKU_T_KOJIAK.YZAHYO_5));

		// 設備向けコード変換（分類コード、新料金プラン）
		HashMap<String, String> newPplanCdMap = getNewPplanCd(ku0011Map);
		
		// 分類コード
		outMap.setString(JBSbatKUIFE023.BUNRUI_CD, newPplanCdMap.get(JKUStrConst.RNKI_SYS_KKEI_SVC_CD));
		
		// 新料金プラン
		outMap.setString(JBSbatKUIFE023.NEW_PPLAN_CD, newPplanCdMap.get(JKUStrConst.RNKI_SYS_PPLAN_CD));

		// 旧料金プラン
		outMap.setString(JBSbatKUIFE023.OLD_PPLAN_CD, null);

		// ＳＹＳＩＤ
		outMap.setString(JBSbatKUIFE023.SYSID, ku0011Map.getString(JBSbatKU_T_KOJIAK.SYSID));

		// 元工事案件番号
		outMap.setString(JBSbatKUIFE023.MOTO_KOJIAK_NO, null);

		// 座標補正有無
		outMap.setString(JBSbatKUIFE023.ZAHYO_HOSEI_UM, null);

		// 面開発判定
		String menkaihatAnkenNo = null;
		String mnkhtKojiCd = null;
		if (JKUStrConst.CD00577_MNKHT.equals(ku0011Map.getString(JBSbatKU_T_KOJIAK.KOJIAK_SBT_CD)))
		{
			// 工事案件種別コードが「面開発」の場合は、先行設計の面開発案件番号を設定する。
			menkaihatAnkenNo = senkouMap.getString(JBSbatKU_T_SENKO_DSGN.MENKAIHAT_ANKEN_NO);
			// 工事案件種別コードが「面開発」の場合は、先行設計の面開発工事コードを設定する。
			mnkhtKojiCd = senkouMap.getString(JBSbatKU_T_SENKO_DSGN.MNKHT_KOJI_CD);
		}
		
		// 面開発案件番号
		outMap.setString(JBSbatKUIFE023.MENKAIHAT_ANKEN_NO, menkaihatAnkenNo);
		
		// 面開発工事コード
		outMap.setString(JBSbatKUIFE023.MNKHT_KOJI_CD, mnkhtKojiCd);

		// 同時工事案件番号
		outMap.setString(JBSbatKUIFE023.DOJI_KOJIAK_NO, null);

		// 追加サービス契約番号
		outMap.setString(JBSbatKUIFE023.ADD_SVC_KEI_NO, null);

		// 設計依頼年月日
		outMap.setString(JBSbatKUIFE023.DSGN_REQ_YMD, senkouMap.getString(JBSbatKU_T_SENKO_DSGN.DSGN_REQYMD));
		
		// Ｐ−ＩＤ
		outMap.setString(JBSbatKUIFE023.PID, ku0011Map.getString(JBSbatKU_T_KOJIAK.PID));
		
		// 電波障害案件種別コード設定値判定
		String dojiDaihyo = ku0011Map.getString(JBSbatKU_T_KOJIAK.DOJI_DAIHYO_KOJIAK_NO);
		String dmpsankSbtCd = senkouMap.getString(JBSbatKU_T_SENKO_DSGN.DMPSANK_SBT_CD);
		String setDmpsanksbtcd = JKUBatCommon.checkDoujiDmpsankSbtCd(dojiDaihyo, dmpsankSbtCd);
		
		// 電波障害案件種別コード
		outMap.setString(JBSbatKUIFE023.DMPSANK_SBT_CD, setDmpsanksbtcd);
		
// ANK-3366-00-00 ADD START
		//卸先事業者コード 
		outMap.setString(JBSbatKUIFE023.ORSJGS_CD, orsjgsCd);
// ANK-3366-00-00 ADD END

// ANK-3885-00-00 ADD START

		// DBを検索
		String kojiakNo = ku0011Map.getString(JBSbatKU_T_KOJIAK.UPD_TRGT_KOJIAK_NO);
		String[] whereParam = {kojiakNo};

		// 工事案件＜eo光ネットマンション＞
		JBSbatCommonDBInterface ku0061DBI = executeKU_T_KJAK_EOH_NTMANS_PKSELECT(whereParam);

		// 編集項目追加
		if (null != ku0061DBI)
		{
// ANK-4493-00-00 MOD START
//			if(JKUStrConst.CD01213_ONU.equals(ku0061DBI.getString(JBSbatKU_T_KJAK_EOH_NTMANS.TK_HOSHIKI_PATTERN_CD)) && 
//				JKUStrConst.UM_YK.equals(ku0061DBI.getString(JBSbatKU_T_KJAK_EOH_NTMANS.HHS_1GONLY_FLG)))
			// 提供方式パターンコードが「ONU」かつ、光配線１Gのみフラグが「対象」の場合、または
			// 提供方式パターンコードが「光配線：コース変更可能」の場合
			if((JKUStrConst.CD01213_ONU.equals(ku0061DBI.getString(JBSbatKU_T_KJAK_EOH_NTMANS.TK_HOSHIKI_PATTERN_CD)) && 
				JKUStrConst.UM_YK.equals(ku0061DBI.getString(JBSbatKU_T_KJAK_EOH_NTMANS.HHS_1GONLY_FLG))) ||
				JKUStrConst.CD01213_HHS_CSCHPSB.equals(ku0061DBI.getString(JBSbatKU_T_KJAK_EOH_NTMANS.TK_HOSHIKI_PATTERN_CD)))
// ANK-4493-00-00 MOD END
			{
				outMap.setString(JBSbatKUIFE023.TOU_INFO, ku0061DBI.getString(JBSbatKU_T_KJAK_EOH_NTMANS.TOU_INFO));
				outMap.setString(JBSbatKUIFE023.HHS_1GONLY_FLG,ku0061DBI.getString(JBSbatKU_T_KJAK_EOH_NTMANS.HHS_1GONLY_FLG));
			}
			else
			{
				outMap.setString(JBSbatKUIFE023.TOU_INFO, "");
				outMap.setString(JBSbatKUIFE023.HHS_1GONLY_FLG, "");
			}
		}
		else
		{
			outMap.setString(JBSbatKUIFE023.TOU_INFO, "");
			outMap.setString(JBSbatKUIFE023.HHS_1GONLY_FLG, "");
		}

// ANK-3885-00-00 ADD START

//ANK-4244-00-00 ADD START
		outMap.setString(JBSbatKUIFE023.KAISEN_PLACE_RENBAN, ku0011Map.getString(JBSbatKU_T_KOJIAK.KAISEN_PLACE_RENBAN));
//ANK-4244-00-00 ADD END
		return outMap;
	}
	
	/**
	 * 工事案件を検索します。
	 * @param kojiakNo 工事案件番号
	 * @return 工事案件テーブル１レコード（取得できなかった場合はnull）
	 * @throws Exception
	 */
	private JBSbatCommonDBInterface findKU_T_KOJIAK(String kojiakNo) throws Exception
	{
		// 検索処理に渡すパラメタを設定
		Object[] whereParam = new Object[1];
		
		whereParam[0] = kojiakNo;
		
		// 検索処理実行
		return this.executeKU_T_KOJIAK_PKSELECT(whereParam);

	}
	
	/**
	 * 先行設計を検索します。
	 * @param kojiakNo 工事案件番号
	 * @return 先行設計検索結果１レコード（取得できなかった場合はnull）
	 * @throws Exception
	 */
	private JBSbatCommonDBInterface findKU_T_SENKO(String kojiakNo) throws Exception
	{
		Object[] whereParam = new Object[1];
		
		whereParam[0] = kojiakNo;
		
		// 検索処理実行
		this.executeKU_T_SENKO_DSGN_KU_SELECT_004(whereParam);
		
		return db_KU_T_SENKO_DSGN.selectNext();
	}
// ANK-4285-00-00 MOD START
//	/**
//	 * 工事案件を更新します。
//	 * @param kojiakNo 工事案件番号
//	 * @throws Exception
//	 */
//	private void updateKU_T_KOJIAK(String kojiakNo) throws Exception
//	{
//		// 更新処理に渡すパラメタを設定
//		Object[] setParam = new Object[2];
//		Object[] whereParam = new Object[1];
//		
//		// Ｇｅｎｅｓｉｓ連携種別コード
//		setParam[0] = JKUStrConst.CD00699_EQUIP_DEL_RENKEIZM;
//		// Ｇｅｎｅｓｉｓ連携種別変更年月日時分秒
//		setParam[1] = JKUBatCommon.getSysDateTime();
//		
//		// 工事案件番号
//		whereParam[0] = kojiakNo;
//			
//		this.executeKU_T_KOJIAK_PKUPDATE(setParam, whereParam);
//	}
	/**
	 * 工事案件を更新します。
	 * @param kojiakNo 工事案件番号
	 * @param genesisSbtCd Genesis連携種別コード
	 * @param kojiScopeCd 工事範囲コード
	 * @throws Exception
	 */
	private void updateKU_T_KOJIAK(String kojiakNo, String genesisSbtCd, String kojiScopeCd) throws Exception
	{
		// 更新処理に渡すパラメタを設定
		Object[] setParam = new Object[2];
		Object[] whereParam = new Object[1];
		
		// Ｇｅｎｅｓｉｓ連携種別コード
		 if (JKUStrConst.CD00699_KOJI_FIN_RENKEIZM.equals(genesisSbtCd) && (KOJI_SCOPE_CD_CUT_TOOL_USE.equals(kojiScopeCd) || KOJI_SCOPE_CD_RZT_ZM_KJ_FYO_ANK.equals(kojiScopeCd))){
			 setParam[0] = JKUStrConst.CD00699_DSL_RENKEIZM_HMPIN_MIRENKEI;
		 }
		 else {
			 setParam[0] = JKUStrConst.CD00699_EQUIP_DEL_RENKEIZM;
		 }
		
		// Ｇｅｎｅｓｉｓ連携種別変更年月日時分秒
		setParam[1] = JKUBatCommon.getSysDateTime();
		
		// 工事案件番号
		whereParam[0] = kojiakNo;
			
		this.executeKU_T_KOJIAK_PKUPDATE(setParam, whereParam);
	}
// ANK-4285-00-00 MOD END
	
	/**
	 * 経過日数チェックを行います。
	 * @param ku0011Map 工事案件情報
	 * @return true:一定期間経過している場合。false:一定期間経過していない場合。
	 * @throws Exception
	 */
	private boolean checkDateDiff(JBSbatCommonDBInterface ku0011Map) throws Exception
	{
		// 工事案件種別コード
		String kojiakSbtCd = ku0011Map.getString(JBSbatKU_T_KOJIAK.KOJIAK_SBT_CD);
		
		// チェック対象年月日
		String taishoYmd = null;
		
		if (JKUStrConst.CD00577_AD_CHG_TEKKYO.equals(kojiakSbtCd))
		{
			// 工事案件種別コードが「住所変更(撤去)工事」の場合
			// 最終応答結果コード変更年月日
			taishoYmd = ku0011Map.getString(JBSbatKU_T_KOJIAK.LAST_RSP_RSLT_CD_CHG_YMD);
		}
		else if(JKUStrConst.CD00577_PLAN_CHG_SHUYO.equals(kojiakSbtCd))
		{
			// 工事案件種別コードが「プラン変更(収容替)」の場合
			// プラン変更確定年月日
			taishoYmd = JKUBatCommon.toYmdFromDtm(ku0011Map.getString(JBSbatKU_T_KOJIAK.PLAN_CHG_FIX_DTM));
		}
		else
		{
			// 上記以外の場合、経過日数チェックを行わない
			return true;
		}
		
		// 旧設備削除情報抽出経過日数チェック
		if(taishoYmd == null
				|| Integer.valueOf(ku_OLDEQUIP_CST_DAYS) > JKUBatCommon.subtractDay(super.opeDate, taishoYmd))
		{
			return false;
		}
		
		return true;
	}

	/**
	 * 新料金プランコード設定のためのMapを取得します。
	 * @param ku0011Map 工事案件情報
	 * @return 新料金プランコードマップ
	 * @throws Exception
	 */
	private HashMap<String, String> getNewPplanCd(JBSbatCommonDBInterface ku0011Map) throws Exception
	{
		// 設備向けコード変換（分類コード、新料金プラン）
		HashMap<String, String> paramMap = new HashMap<String, String>();
		HashMap<String, String> rsltMap = new HashMap<String, String>();

		// インターネットオフィスの判定
		if (null == ku0011Map.getString(JBSbatKU_T_KOJIAK.HOJIN_PRC_GRP_CD))
		{
			// インターネットオフィス以外の場合
			paramMap.put(JKUStrConst.RNKI_SYS_PRC_GRP_CD, ku0011Map.getString(JBSbatKU_T_KOJIAK.PRC_GRP_CD));
			paramMap.put(JKUStrConst.RNKI_SYS_PCRS_CD, ku0011Map.getString(JBSbatKU_T_KOJIAK.PCRS_CD));
			paramMap.put(JKUStrConst.RNKI_SYS_PPLAN_CD, ku0011Map.getString(JBSbatKU_T_KOJIAK.PPLAN_CD));
			paramMap.put(JKUStrConst.RNKI_SYS_WRIB_TYPE_CD, ku0011Map.getString(JBSbatKU_T_KOJIAK.WRIB_TYPE_CD));
			paramMap.put(JKUStrConst.RNKI_SYS_MANS_BUKKEN_CD, ku0011Map.getString(JBSbatKU_T_KOJIAK.MANSION_BUKKEN_CD));
			paramMap.put(JKUStrConst.RNKI_SYS_SYSTEM, JKUStrConst.RNKI_SYSTEM_GENESIS);
		}
		else
		{
			// インターネットオフィスの場合
			paramMap.put(JKUStrConst.RNKI_SYS_PRC_GRP_CD, ku0011Map.getString(JBSbatKU_T_KOJIAK.HOJIN_PRC_GRP_CD));
			paramMap.put(JKUStrConst.RNKI_SYS_PCRS_CD, ku0011Map.getString(JBSbatKU_T_KOJIAK.HOJIN_PCRS_CD));
			paramMap.put(JKUStrConst.RNKI_SYS_PPLAN_CD, ku0011Map.getString(JBSbatKU_T_KOJIAK.HOJIN_PPLAN_CD));
			paramMap.put(JKUStrConst.RNKI_SYS_WRIB_TYPE_CD, null);
			paramMap.put(JKUStrConst.RNKI_SYS_MANS_BUKKEN_CD, null);
			paramMap.put(JKUStrConst.RNKI_SYS_SYSTEM, JKUStrConst.RNKI_SYSTEM_GENESIS);
		}
		
		rsltMap = JKUBatCommon.getSetsubiCodeMap(commonItem, ku0011Map.getString(JBSbatKU_T_KOJIAK.KOJIAK_NO), paramMap, dKuTKjakEohNtMans);
		
		if (null == rsltMap)
		{
			// ログ出力し、次レコードへ
			super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.EKUB0720KW, new String[]{
					ku0011Map.getString(JBSbatKU_T_KOJIAK.KOJIAK_NO),
					JKUBatCommon.convMapToString(paramMap)});
			
			throw new JBSbatBusinessError();
		}
		
		return rsltMap;
	}
	
// ANK-3366-00-00 ADD START
	/**
	 * お客様から卸先事業者コードを検索します。
	 * @param sysidParam 工事案件SYSID
	 * @return String 卸先事業者コード
	 * @throws Exception
	 */
	private String findOrsjgsCd(String sysidParam) throws Exception
	{
		/** DBアクセス結果を取得するためのMap */
		JBSbatCommonDBInterface custMap = new JBSbatCommonDBInterface();

		// 卸先事業者コード
		String orsjgsCd =null;
		
		// 検索処理に渡すパラメタを設定
		Object[] whereParam = new Object[2];
		whereParam[0] = sysidParam;
		whereParam[1] = super.opeDate;
		
		// 検索処理実行
		this.executeCK_T_CUST_KU_SELECT_001(whereParam);
		
		// 検索結果の１件を取得する
		custMap = db_CK_T_CUST.selectNext();
		
		// お客様がある場合は、卸先事業者コードを戻す
		if(custMap != null)
		{
// ANK-4269-00-00 MOD START
//			orsjgsCd = custMap.getString(JBSbatCK_T_CUST.ORSJGS_CD);
			if(custMap.getString(JBSbatCK_T_CUST.SCM_JGS_CD) != null){
				orsjgsCd = custMap.getString(JBSbatCK_T_CUST.SCM_JGS_CD);
			}
			else
			{
				orsjgsCd = custMap.getString(JBSbatCK_T_CUST.ORSJGS_CD);
			}
// ANK-4269-00-00 MOD END
		}
		
		return orsjgsCd;
	}

	/**
	 * SQLKEY(KU_SELECT_001)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	SYSID
	 *		 	予約適用年月日
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeCK_T_CUST_KU_SELECT_001(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());
		paramList.setValue(param[1].toString());

		// DBアクセスを実行します
		db_CK_T_CUST.selectBySqlDefine(paramList, CK_T_CUST_KU_SELECT_001);
	}
//ANK-3366-00-00 ADD END
	/**▲▲▲▲▲▲業務チームで作成したメソッドです 終了▲▲▲▲▲▲*/

//ANK-3885-00-00 ADD START
		/**
	 * 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_KJAK_EOH_NTMANS_PKSELECT(Object[] whereParam) throws Exception
	{
		// 条件のマップを作成します
		JBSbatCommonDBInterface whereMap = new JBSbatCommonDBInterface();
		whereMap.setValue("KOJIAK_NO", whereParam[0]);

		// DBアクセスを実行します
		return dKuTKjakEohNtMans.selectByPrimaryKeys(whereMap);
	}
//ANK-3885-00-00 ADD END


}
