/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatKKAdHenkoDataChstu
*	ソースファイル名	：JBSbatKKAdHenkoDataChstu.java
*	作成者				：富士通　
*	作成日				：2012年09月01日
*＜機能概要＞
*　住所マスタから変更住所レコードデータ抽出部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00    2012/09/01  富士通	    新規作成
*********************************************************************/
package eo.business.service;

import eo.business.common.JBSbatBusinessService;
import eo.business.common.JCCBatCommon;
import eo.business.common.JZMBatCommon;
import eo.business.util.table.JBSbatKK_T_CHGTGAD_CD_WK;
import eo.business.util.table.JBSbatZM_M_AD;
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;

/**
* 住所マスタから変更住所レコードデータ抽出クラスです。<p>
*<BR>
* @author 富士通
*/
public class JBSbatKKAdHenkoDataChstu extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/** テーブルアクセスクラス*/
	private JBSbatSQLAccess dbAccess = null;
	private JBSbatSQLAccess dbAccess2 = null;
	private JBSbatSQLAccess db_CHGTGAD_CD_WK = null;
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/

	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// DBアクセスクラスを生成します
		dbAccess = new JBSbatSQLAccess(commonItem, "ZM_M_AD");
		dbAccess2 = new JBSbatSQLAccess(commonItem, "ZM_M_AD");
		db_CHGTGAD_CD_WK = new JBSbatSQLAccess(commonItem, "KK_T_CHGTGAD_CD_WK");

		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @param inMap　入力電文
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute(JBSbatServiceInterfaceMap inMap) throws Exception
	{

	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		//String sysDate = JCCBatCommon.getSysDateTime();

		String adSelYMD = JZMBatCommon.getInMapData(inMap, "AD_SEL_YMD");
		if(null == adSelYMD) adSelYMD = "";
		
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		//***<< 2012/10/15 運用日からシステム日付に変更 K.IWASA ins [S] >>***/
		String sysDate = JCCBatCommon.getSysDateTime();
		//***<< 2012/10/15 運用日からシステム日付に変更 K.IWASA ins [E] >>***/
		
		//検索条件の設定
		paramList.setValue(adSelYMD);
		//***<< 2012/12/25 SQLをBETWEENから不等号に変更 K.IWASA upd [S] >>***/
//		paramList.setValue(sysDate);
		//paramList.setValue(super.opeDate);
		//***<< 2012/12/25 SQLをBETWEENから不等号に変更 K.IWASA upd [E] >>***/

		super.logPrint.printDebugLog("前回運用日：" + adSelYMD);
		//***<< 2012/10/15 運用日からシステム日付に変更 K.IWASA upd [S] >>***/
		super.logPrint.printDebugLog("今回運用日：" + sysDate);
		//super.logPrint.printDebugLog("今回運用日：" + super.opeDate);
		//***<< 2012/10/15 運用日からシステム日付に変更 K.IWASA upd [E] >>***/

		// DBアクセスを実行します
		dbAccess.selectBySqlDefine(paramList, "KK_SELECT_008");

		// SQL実行結果取得用map
		JBSbatCommonDBInterface map = null;
		
		//***<< 2013/11/06 SQL実行結果取得用mapを追加 A.SUMITOMO ins [S] >>***/
		JBSbatCommonDBInterface map2 = null;
		//***<< 2013/11/06 SQL実行結果取得用mapを追加 A.SUMITOMO ins [E] >>***/

		for (map = dbAccess.selectNext(); null != map; map = dbAccess.selectNext())
		{
			//***<< 2013/11/06 出力対象外条件を追加 A.SUMITOMO ins [S] >>***/
			if ((map.getString(JBSbatZM_M_AD.AD_SHUSEI_CD).equals("3")) && 
				(map.getString(JBSbatZM_M_AD.AD_CHG_SBT_CD).equals("11") || map.getString(JBSbatZM_M_AD.AD_CHG_SBT_CD).equals("12"))) {
				
				// バイント変数のリストを生成します
				JBSbatCommonDBInterface paramList2 = new JBSbatCommonDBInterface();
				paramList2.setValue(map.getString(JBSbatZM_M_AD.AD_CD));
				paramList2.setValue(map.getString(JBSbatZM_M_AD.GENE_ADD_DTM));
				
				// DBアクセスを実行します
				// 最新世代レコードの一つ前のレコードを取得する
				dbAccess2.selectBySqlDefine(paramList2, "KK_SELECT_010");
				
				map2 = dbAccess2.selectNext();
				
				if (map2 !=null){
					
					// 値がnullの場合、文字列「null」を以外はそのままの値を比較用の変数に設定する
					String n_PCD       = String.valueOf(map.getString(JBSbatZM_M_AD.PCD));
					String n_STATE_NM  = String.valueOf(map.getString(JBSbatZM_M_AD.STATE_NM));
					String n_CITY_NM   = String.valueOf(map.getString(JBSbatZM_M_AD.CITY_NM));
					String n_OAZTSU_NM = String.valueOf(map.getString(JBSbatZM_M_AD.OAZTSU_NM));
					String n_AZCHO_NM  = String.valueOf(map.getString(JBSbatZM_M_AD.AZCHO_NM));
					String o_PCD       = String.valueOf(map2.getString(JBSbatZM_M_AD.PCD));
					String o_STATE_NM  = String.valueOf(map2.getString(JBSbatZM_M_AD.STATE_NM));
					String o_CITY_NM   = String.valueOf(map2.getString(JBSbatZM_M_AD.CITY_NM));
					String o_OAZTSU_NM = String.valueOf(map2.getString(JBSbatZM_M_AD.OAZTSU_NM));
					String o_AZCHO_NM  = String.valueOf(map2.getString(JBSbatZM_M_AD.AZCHO_NM));
					
					// 最新世代の値とその一つ前の世代の値を比較する
					if (o_PCD.equals(n_PCD)            && 
						o_STATE_NM.equals(n_STATE_NM)   && 
						o_CITY_NM.equals(n_CITY_NM)     && 
						o_OAZTSU_NM.equals(n_OAZTSU_NM) &&
						o_AZCHO_NM.equals(n_AZCHO_NM))  {
						continue;
					}
				}
			}
			//***<< 2013/11/06 出力対象外条件を追加 A.SUMITOMO ins [E] >>***/
			
			//パラメタ設定
			JBSbatCommonDBInterface inDbMap = new JBSbatCommonDBInterface ();
			inDbMap. setValue(JBSbatKK_T_CHGTGAD_CD_WK.AD_CD, map.getString(JBSbatZM_M_AD.AD_CD));
			inDbMap. setValue(JBSbatKK_T_CHGTGAD_CD_WK.PCD, map.getString(JBSbatZM_M_AD.PCD));
			inDbMap. setValue(JBSbatKK_T_CHGTGAD_CD_WK.STATE_NM, map.getString(JBSbatZM_M_AD.STATE_NM));
			inDbMap. setValue(JBSbatKK_T_CHGTGAD_CD_WK.CITY_NM, map.getString(JBSbatZM_M_AD.CITY_NM));
			inDbMap. setValue(JBSbatKK_T_CHGTGAD_CD_WK.OAZTSU_NM, map.getString(JBSbatZM_M_AD.OAZTSU_NM));
			inDbMap. setValue(JBSbatKK_T_CHGTGAD_CD_WK.AZCHO_NM, map.getString(JBSbatZM_M_AD.AZCHO_NM));
			inDbMap. setValue(JBSbatKK_T_CHGTGAD_CD_WK.AD_SHUSEI_CD, map.getString(JBSbatZM_M_AD.AD_SHUSEI_CD));
			inDbMap. setValue(JBSbatKK_T_CHGTGAD_CD_WK.NEW_AD_CD, map.getString("NEW_AD_CD"));
			inDbMap. setValue(JBSbatKK_T_CHGTGAD_CD_WK.NEW_PCD, map.getString("NEW_PCD"));
			inDbMap. setValue(JBSbatKK_T_CHGTGAD_CD_WK.NEW_STATE_NM, map.getString("NEW_STATE_NM"));
			inDbMap. setValue(JBSbatKK_T_CHGTGAD_CD_WK.NEW_CITY_NM, map.getString("NEW_CITY_NM"));
			inDbMap. setValue(JBSbatKK_T_CHGTGAD_CD_WK.NEW_OAZTSU_NM, map.getString("NEW_OAZTSU_NM"));
			inDbMap. setValue(JBSbatKK_T_CHGTGAD_CD_WK.NEW_AZCHO_NM, map.getString("NEW_AZCHO_NM"));
			inDbMap. setValue(JBSbatKK_T_CHGTGAD_CD_WK.AD_CHG_SBT_CD, map.getString(JBSbatZM_M_AD.AD_CHG_SBT_CD));
			inDbMap. setValue(JBSbatKK_T_CHGTGAD_CD_WK.CHG_AD_TRN_STAT_CD, "0");
			inDbMap. setValue(JBSbatKK_T_CHGTGAD_CD_WK.CKADGAI_CHG_AD_TRN_STAT_CD, "0");
			inDbMap. setValue(JBSbatKK_T_CHGTGAD_CD_WK.MANIPT_CHG_AD_TRN_STAT_CD, "0");

			//INSERT文発行
			int count = db_CHGTGAD_CD_WK.insertByPrimaryKeys(inDbMap);
		}
		
		return null;
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
		
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		// DBアクセスクラスをクローズします
		dbAccess.close();
		dbAccess2.close();
		db_CHGTGAD_CD_WK.close();
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/
}
