/*********************************************************************
*  All Rights reserved,Copyright (c) K-Opticom
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatACPctCntStku
*	ソースファイル名	：JBSbatACPctCntStku.java
*	作成者				：富士通　
*	作成日				：2011年12月12日
*＜機能概要＞
*　パケット数取得部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v1.00.00	2011/12/12   富士通		新規作成
*********************************************************************/
package eo.business.service;

import java.math.BigDecimal;
import java.util.HashMap;

import eo.business.common.JACbatDebugLogUtil;
import eo.business.common.JACbatRknBusinessUtil;
import eo.business.common.JBSbatBusinessService;
import eo.business.common.JCHbatSeikyKaknoBusinessUtil;
import eo.business.util.file.JBSbatACIFI016;
import eo.business.util.table.JBSbatAC_M_JURYOPRC;
import eo.business.util.table.JBSbatAC_T_CHRG_JSVKEI_CKS;
import eo.common.constant.JACStrConst;
import eo.common.constant.JPCBatchMessageConstant;
import eo.framework.item.JBSbatCommonItem;
import eo.framework.item.JBSbatServiceInterfaceMap;
import eo.framework.item.JBSbatOutputItem;
import eo.framework.item.JBSbatCommonDBInterface;
import eo.framework.application.JBSbatBusinessException;
import eo.framework.db.JBSbatSQLAccess;

/**
* (クラスの機能概要) <p>
*<BR>
* @author 富士通
*/
public class JBSbatACPctCntStku extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/** テーブル(従量料金)*/
	private static final String D_TBL_NAME_AC_M_JURYOPRC = "AC_M_JURYOPRC";

	/** テーブル(料金スケジュール定義)*/
	private static final String D_TBL_NAME_CH_M_PRC_SCHDL_TEIGI = "CH_M_PRC_SCHDL_TEIGI";

	/** テーブル(課金対象従量サービス契約蓄積)*/
	private static final String D_TBL_NAME_AC_T_CHRG_JSVKEI_CKS = "AC_T_CHRG_JSVKEI_CKS";

	/** SQL定義キー(AC_SELECT_002)*/
	private static final String AC_M_JURYOPRC_AC_SELECT_002 = "AC_SELECT_002";

	/** SQL定義キー(AC_SELECT_005)*/
	private static final String AC_T_CHRG_JSVKEI_CKS_AC_SELECT_005 = "AC_SELECT_005";

	/** テーブルアクセスクラス(従量料金)*/
	private JBSbatSQLAccess db_AC_M_JURYOPRC = null;

	/** テーブルアクセスクラス(料金スケジュール定義)*/
	private JBSbatSQLAccess db_CH_M_PRC_SCHDL_TEIGI = null;

	/** テーブルアクセスクラス(課金対象従量サービス契約蓄積)*/
	private JBSbatSQLAccess db_AC_T_CHRG_JSVKEI_CKS = null;
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/
	
	/** 退避.パケット数計算用係数マップ */
	private HashMap<String, JBSbatCommonDBInterface> taihiPctCntMap 	= null;
	/** 退避.相対番号 */
	private String taihiAitNo 											= null;
	/** 退避.相対番号２ */
	private String taihiAitNo2 										= null;
	/** 退避.パケット数 */
	private BigDecimal pctCnt											= new BigDecimal("0");
	/** 請求収納業務共通クラス */
	private JCHbatSeikyKaknoBusinessUtil chBusinessUtil 				= null;

	/** 通話種別桁数*/
	private static final int TUWA_SBT_CNT 							= 2;
	/** 通話種別空白用ダミー*/
	private static final String TUWA_SBT_DUMMY 						= " ";
	
	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception 業務サービス内で発生した例外全般
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);

		// DBアクセスクラスを生成します
		db_AC_M_JURYOPRC = new JBSbatSQLAccess(commonItem, D_TBL_NAME_AC_M_JURYOPRC);
		db_CH_M_PRC_SCHDL_TEIGI = new JBSbatSQLAccess(commonItem, D_TBL_NAME_CH_M_PRC_SCHDL_TEIGI);
		db_AC_T_CHRG_JSVKEI_CKS = new JBSbatSQLAccess(commonItem, D_TBL_NAME_AC_T_CHRG_JSVKEI_CKS);
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/
		assert 	JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][initial]");

		chBusinessUtil = new JCHbatSeikyKaknoBusinessUtil(commonItem);
		// パケット数計算用係数取得
		getPctCnt();
		assert 	JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][initial]");
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * パケット数計算用係数取得
	 * @throws Exception 業務サービス内で発生した例外全般
	 */
	public void getPctCnt() throws Exception
	{
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][getPctCnt]");
		
		// 取得結果格納用マップを初期化
		this.taihiPctCntMap = new HashMap<String, JBSbatCommonDBInterface>();
		
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		// マップ格納キー
		String juryoPrcKey = null;
		// システムコード
		paramList.setValue(super.systemCode);
		// 課税非課税コード（課税）
		paramList.setValue(JACStrConst.KAZEI_HIKAZEI_CD_KAZEI);
		// バッチ運用日
		paramList.setValue(super.opeDate);
		// バッチ運用日
		paramList.setValue(super.opeDate);
		// バッチ運用日
		paramList.setValue(super.opeDate);
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][getPctCalcKeisu][paramList=" + paramList.getList().toString() + "]");		
		
		// SQL実行
		executeAC_M_JURYOPRC_AC_SELECT_002(paramList.getList().toArray());
		// 結果を取得
		JBSbatCommonDBInterface dbMap =  db_AC_M_JURYOPRC.selectNext();
		// 取得できた場合
		if(dbMap != null)
		{
			// 取得結果を全件退避させる
			while(dbMap != null)
			{
				// マップ格納キーを設定する
				juryoPrcKey = dbMap.getString(JBSbatAC_M_JURYOPRC.PCRS_CD) 		// 料金コースコード 	+
							+ dbMap.getString(JBSbatAC_M_JURYOPRC.PRC_SVC_CD) 	// 料金サービスコード 	+
							+ dbMap.getString(JBSbatAC_M_JURYOPRC.AITAI_NO);	// 相対番号
				this.taihiPctCntMap.put(juryoPrcKey, dbMap);
				assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][getPctCnt][dbMap=" + dbMap.getMap().toString() + "]");	
				dbMap =  db_AC_M_JURYOPRC.selectNext();
				juryoPrcKey = null;
			}
		}
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][getPctCnt]");
	}

	/**
	 * 主処理
	 * @param inMap　入力電文
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception 業務サービス内で発生した例外全般
	 */
	public JBSbatOutputItem execute(JBSbatServiceInterfaceMap inMap) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		assert 	JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][execute]");
		assert inMap 			!= null ? JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][execute][inMap = " + inMap.getMap().toString() + "]") : true;
		
		// 出力情報マップ
		JBSbatOutputItem outputItem 			= new JBSbatOutputItem();
		// 出力情報データ格納マップ
		JBSbatServiceInterfaceMap outMap 		= new JBSbatServiceInterfaceMap();
		
		JBSbatCommonDBInterface outInfoMap 		= new JBSbatCommonDBInterface();
		
		// 出力用情報取得
		outInfoMap = getOutInfo(inMap);
		if(outInfoMap == null)
		{
			// 出力情報取得できなかった場合、出力しないで次のレコードへ処理を継続
			return null;
		}
		// EM法人利用料金情報作成
		outMap = makeEmHojinPrcInfo(inMap, outInfoMap);
		outputItem.addOutMapList(outMap);

		assert 	JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][execute]");

		return outputItem;
	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * EM法人利用料金情報作成
	 * @param  inMap 入力情報
	 * @param  outInfoMap 課金対象従量サービス契約蓄積
	 * @return JBSbatServiceInterfaceMap EM法人利用料金情報
	 * @throws Exception 業務サービス内で発生した例外全般
	 */
	private JBSbatServiceInterfaceMap makeEmHojinPrcInfo(JBSbatServiceInterfaceMap inMap, JBSbatCommonDBInterface outInfoMap) throws Exception
	{

		// EM法人利用料金情報マップ
		JBSbatServiceInterfaceMap outMap 		= new JBSbatServiceInterfaceMap();
		
		//  1.請求先番号
		outMap.set(JBSbatACIFI016.SEIKY_KEI_NO, 		inMap.getString(JBSbatACIFI016.SEIKY_KEI_NO));
		//  2.請求年月
		outMap.set(JBSbatACIFI016.SEIKY_YM, 			inMap.getString(JBSbatACIFI016.SEIKY_YM));
		//  3.割引サービス契約番号
		outMap.set(JBSbatACIFI016.WRIB_SVC_KEI_NO, 		inMap.getString(JBSbatACIFI016.WRIB_SVC_KEI_NO));
		//  4.割引サービス対象契約番号
		outMap.set(JBSbatACIFI016.WRISVC_TRGT_KEI_NO, 	inMap.getString(JBSbatACIFI016.WRISVC_TRGT_KEI_NO));
		//  5.サービス番号
		outMap.set(JBSbatACIFI016.SVC_NO, 				outInfoMap.getString(JBSbatAC_T_CHRG_JSVKEI_CKS.SVC_KEI_NO));
		//  6.料金サービス識別コード
		outMap.set(JBSbatACIFI016.SVC_SKBT_CD, 			inMap.getString(JBSbatACIFI016.SVC_SKBT_CD));
		//  7.料金コースコード
		outMap.set(JBSbatACIFI016.PCRS_CD, 				outInfoMap.getString(JBSbatAC_T_CHRG_JSVKEI_CKS.PCRS_CD));
		//  8.料金サービスコード
		outMap.set(JBSbatACIFI016.PRC_SVC_CD, 			outInfoMap.getString(JBSbatAC_T_CHRG_JSVKEI_CKS.PRC_SVC_CD));
		//  9.料金項目コード
		outMap.set(JBSbatACIFI016.PRC_KMK_CD, 			inMap.getString(JBSbatACIFI016.PRC_KMK_CD));
		// 10.徴収パターンコード
		outMap.set(JBSbatACIFI016.COLLECT_PATTERN_CD, 	inMap.getString(JBSbatACIFI016.COLLECT_PATTERN_CD));
		// 11.料金
		outMap.set(JBSbatACIFI016.PRC, 					this.pctCnt);
		// 12.利用開始日
		outMap.set(JBSbatACIFI016.USE_STAYMD, 			inMap.getString(JBSbatACIFI016.USE_STAYMD));
		// 13.利用終了日
		outMap.set(JBSbatACIFI016.USE_ENDYMD, 			inMap.getString(JBSbatACIFI016.USE_ENDYMD));
		// 14.サービス開始日
		outMap.set(JBSbatACIFI016.SVC_STAYMD, 			outInfoMap.getString(JBSbatAC_T_CHRG_JSVKEI_CKS.SVC_STAYMD));
		// 15.初回課金開始日
		outMap.set(JBSbatACIFI016.FIRST_CHRG_STAYMD, 	outInfoMap.getString(JBSbatAC_T_CHRG_JSVKEI_CKS.FIRST_CHRG_STAYMD));
		// 16.サービス解約日
		outMap.set(JBSbatACIFI016.SVC_DSL_YMD, 			outInfoMap.getString(JBSbatAC_T_CHRG_JSVKEI_CKS.SVC_DSL_YMD));
		// 17.サービス解約理由
		outMap.set(JBSbatACIFI016.SVC_DLRE, 			inMap.getString(JBSbatACIFI016.SVC_DLRE));
		// 18.サービス回復日
		outMap.set(JBSbatACIFI016.SVC_KAIHK_DAY, 		inMap.getString(JBSbatACIFI016.SVC_KAIHK_DAY));
		// 19.利用日数
		outMap.set(JBSbatACIFI016.USE_DAY_CNT, 			inMap.getBigDecimal(JBSbatACIFI016.USE_DAY_CNT).toString());
		// 20.利用不可日数
		outMap.set(JBSbatACIFI016.USE_FAIL_DAY_CNT, 	inMap.getBigDecimal(JBSbatACIFI016.USE_FAIL_DAY_CNT).toString());
		// 21.相対区分
		outMap.set(JBSbatACIFI016.AIT_DIV, 				inMap.getString(JBSbatACIFI016.AIT_DIV));
		// 22.締め日
		outMap.set(JBSbatACIFI016.SIME_DAY, 			inMap.getString(JBSbatACIFI016.SIME_DAY));
		// 23.利用不可適用可否
		outMap.set(JBSbatACIFI016.USE_APLY_KH_CD, 		inMap.getString(JBSbatACIFI016.USE_APLY_KH_CD));
		// 24.前受相殺優先順位
		outMap.set(JBSbatACIFI016.MAE_YUSEN_JUN, 		inMap.getString(JBSbatACIFI016.MAE_YUSEN_JUN));
		// 25.割引優先順位
		outMap.set(JBSbatACIFI016.WRIB_YUSEN_JUN, 		inMap.getString(JBSbatACIFI016.WRIB_YUSEN_JUN));
		
		// 出力フラグ設定
		outMap.setOutFlg(true);
		
		return outMap;
	}

	/**
	 * 出力用情報取得
	 * @param  inMap 入力情報
	 * @return dbMap 課金対象従量サービス契約蓄積
	 * @throws Exception 業務サービス内で発生した例外全般
	 */
	private JBSbatCommonDBInterface getOutInfo(JBSbatServiceInterfaceMap inMap) throws Exception
	{
		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][getOutInfo]");
		
		// マップ検索キー
		String serchMapKey 					= null;
		// マップ検索キー２
		String serchMapKey2					= null;
		// 退避.計算用係数マップ
		JBSbatCommonDBInterface calcMap		= new JBSbatCommonDBInterface();
		// BigDecimal変換用:料金
		BigDecimal bigPrc					= BigDecimal.ZERO;
		// BigDecimal変換用:単位料金
		BigDecimal bigTaniPrc 				= BigDecimal.ZERO;
		// BigDecimal変換用:課金単位
		BigDecimal bigChgeTani				= BigDecimal.ZERO;
		
		JBSbatCommonDBInterface paramList 	= new JBSbatCommonDBInterface();
		// EM契約者コード
		paramList.setValue(inMap.getString(JBSbatACIFI016.SEIKY_KEI_NO));
		// 請求年月
		paramList.setValue(inMap.getString(JBSbatACIFI016.SEIKY_YM));
		
		// SQL実行
		executeAC_T_CHRG_JSVKEI_CKS_AC_SELECT_005(paramList.getList().toArray());
		// 結果を取得
		JBSbatCommonDBInterface dbMap =  db_AC_T_CHRG_JSVKEI_CKS.selectNext();
		if(dbMap == null)
		{
			// ログ出力（【最重要】ＤＢ未存在エラー）
			String[] msgParam = new String[]
			{ JBSbatAC_T_CHRG_JSVKEI_CKS.TABLE_NAME, paramList.getList().toString() };
			super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.EACB0250CE, msgParam);
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][getOutInfo:DB未存在エラー上]");
			return null;
		}
		else
		{
			// 相対番号設定
			// 取得した課金対象従量サービス契約蓄積.相対コードが"2"の場合
			if(JACStrConst.AITAI_NO_2.equals(dbMap.getString(JBSbatAC_T_CHRG_JSVKEI_CKS.AITAI_CD)))
			{
				// 退避.相対番号に課金対象従量サービス契約蓄積.請求契約番号を設定
				this.taihiAitNo = dbMap.getString(JBSbatAC_T_CHRG_JSVKEI_CKS.SEIKY_KEI_NO);
			}
			// 取得した課金対象従量サービス契約蓄積.相対コードが"3"の場合
			else if(JACStrConst.AITAI_NO_3.equals(dbMap.getString(JBSbatAC_T_CHRG_JSVKEI_CKS.AITAI_CD)))
			{
				// 退避.相対番号に課金対象従量サービス契約蓄積.サービス契約番号を設定
				this.taihiAitNo = dbMap.getString(JBSbatAC_T_CHRG_JSVKEI_CKS.SVC_KEI_NO);
			}
			// 取得した課金対象従量サービス契約蓄積.相対コードが"2"でも"3"でもない場合
			else
			{
				// 退避.相対番号にALL空白を設定
				this.taihiAitNo = JACStrConst.AITAI_NO_SP;
			}
			// 退避.相対番号2にALL空白を設定
			this.taihiAitNo2 = JACStrConst.AITAI_NO_SP;
		}
		
		// パケット数算出用係数取得
		// マップ検索キーを設定する
		serchMapKey 	= dbMap.getString(JBSbatAC_T_CHRG_JSVKEI_CKS.PCRS_CD) 		// 課金対象従量サービス契約蓄積.料金コースコード
						+ dbMap.getString(JBSbatAC_T_CHRG_JSVKEI_CKS.PRC_SVC_CD) 	// 課金対象従量サービス契約蓄積.料金サービスコード
						+ this.taihiAitNo;											// 退避.相対番号
		// マップ検索キー２を設定する
		serchMapKey2 	= dbMap.getString(JBSbatAC_T_CHRG_JSVKEI_CKS.PCRS_CD) 		// 課金対象従量サービス契約蓄積.料金コースコード
						+ dbMap.getString(JBSbatAC_T_CHRG_JSVKEI_CKS.PRC_SVC_CD) 	// 課金対象従量サービス契約蓄積.料金サービスコード
						+ this.taihiAitNo2;											// 退避.相対番号2
		// マップ検索キーに該当するデータがある場合
		if(this.taihiPctCntMap != null
			&&	this.taihiPctCntMap.get(serchMapKey) != null)
		{
			calcMap 		= this.taihiPctCntMap.get(serchMapKey);
			bigPrc 			= inMap.getBigDecimal(JBSbatACIFI016.PRC);
			bigTaniPrc 		= new BigDecimal(calcMap.getString(JBSbatAC_M_JURYOPRC.TANI_PRC));
			bigChgeTani 	= new BigDecimal(calcMap.getString(JBSbatAC_M_JURYOPRC.CHRG_TANI));
			// 丸め処理(小数点以下切り上げ)
			this.pctCnt 			= JACbatRknBusinessUtil.round(JACStrConst.ROUND_UP, bigPrc.multiply(bigTaniPrc).divide(bigChgeTani, 4, BigDecimal.ROUND_HALF_EVEN), 0);
		}
		// マップ検索キー２に該当するデータがある場合
		else if(this.taihiPctCntMap != null
				&&	this.taihiPctCntMap.get(serchMapKey2) != null)
		{
			calcMap 		= this.taihiPctCntMap.get(serchMapKey2);
			bigPrc 			= inMap.getBigDecimal(JBSbatACIFI016.PRC);
			bigTaniPrc 		= new BigDecimal(calcMap.getString(JBSbatAC_M_JURYOPRC.TANI_PRC));
			bigChgeTani 	= new BigDecimal(calcMap.getString(JBSbatAC_M_JURYOPRC.CHRG_TANI));
			// 丸め処理(小数点以下切り上げ)
			this.pctCnt 			= JACbatRknBusinessUtil.round(JACStrConst.ROUND_UP, bigPrc.multiply(bigTaniPrc).divide(bigChgeTani, 4, BigDecimal.ROUND_HALF_EVEN), 0);
		}
		// 該当するデータがない場合
		else
		{
			// ログ出力（【最重要】ＤＢ未存在エラー）
			String[] msgParam = new String[]
			{ JBSbatAC_T_CHRG_JSVKEI_CKS.TABLE_NAME, paramList.getList().toString() };
			super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.EACB0250CE, msgParam);
			assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][getOutInfo:DB未存在エラー下]");
			return null;
		}
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[L][getOutInfo][paramList=" + paramList.getList().toString() + "]");		
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][getOutInfo]");
		return dbMap;
	}

	/**
	 * 業務サービス終了処理
	 * @throws Exception 業務サービス内で発生した例外全般
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		// DBアクセスクラスをクローズします
		db_AC_M_JURYOPRC.close();
		db_CH_M_PRC_SCHDL_TEIGI.close();
		db_AC_T_CHRG_JSVKEI_CKS.close();
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[S][terminal]");
		assert JACbatDebugLogUtil.printDebugLog(super.logPrint, "[E][terminal]");

	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/

	/**
	 * SQLKEY(AC_SELECT_002)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	システムコード
	 *		 	通話種別コード
	 *		 	バッチ運用日
	 *		 	バッチ運用日
	 *		 	バッチ運用日
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeAC_M_JURYOPRC_AC_SELECT_002(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());
		paramList.setValue(param[1].toString());
		paramList.setValue(param[2].toString());
		paramList.setValue(param[3].toString());
		paramList.setValue(param[4].toString());

		// DBアクセスを実行します
		db_AC_M_JURYOPRC.selectBySqlDefine(paramList, AC_M_JURYOPRC_AC_SELECT_002);
	}

	/**
	 * SQLKEY(AC_SELECT_005)で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 executeAC_T_CHRG_JSVKEI_CKS_AC_SELECT_005(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());
		paramList.setValue(param[1].toString());

		// DBアクセスを実行します
		db_AC_T_CHRG_JSVKEI_CKS.selectBySqlDefine(paramList, AC_T_CHRG_JSVKEI_CKS_AC_SELECT_005);
	}
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/
}
