/*********************************************************************
*  All Rights reserved,Copyright (c) Fujitsu ,2016					 *
**********************************************************************
*＜プログラム内容＞
*	システム名			：eo顧客基幹システム
*	モジュール名		：JBSbatCHMineoRiteiykMailMakeKh
*	ソースファイル名	：JBSbatCHMineoRiteiykMailMakeKh.java
*	作成者				：富士通　
*	作成日				：2016年10月27日
*＜機能概要＞
*　ｍｉｎｅｏ利用停止予告メール送信情報作成（口振）部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	v28.00.00	2016/11/01	FJ)佐々木	新規作成(【ANK-3033-00-00】mineoの利用停止・強制解約処理の自動化
*	v28.00.01	2016/12/04	FJ)佐々木	【IT2-2016-0000058】
*	v28.00.02	2016/12/19	FJ)清原		【ANK-3033-05-00】「利用停止予告メール（口振引落NG)」未収単月時のメール送信文言変更対応
*********************************************************************/
package eo.business.service;


import eo.business.common.JBSbatBusinessService;
import eo.business.common.JCCBatCommon;
import eo.business.common.JKKBatConst;
import eo.business.util.file.JBSbatCHIFE518;
import eo.business.util.file.JBSbatCHIFM096;
import eo.business.util.file.JBSbatCHIFM275;
import eo.business.util.table.JBSbatCC_M_MAIL;
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.JBSbatBusinessError;
import eo.framework.application.JBSbatBusinessException;
import eo.framework.db.JBSbatSQLAccess;
import eo.framework.file.JBSbatOutputFileUtil;
import eo.framework.util.JBSbatDateUtil;

/**
* (クラスの機能概要) <p>
*<BR>
* @author 富士通
*/
public class JBSbatCHMineoRiteiykMailMakeKh extends JBSbatBusinessService
{
	/**▼▼▼▼▼▼ツールから生成した宣言です 開始▼▼▼▼▼▼*/
	/** テーブル(債権)*/
	private static final String D_TBL_NAME_CH_T_SAIKEN = "CH_T_SAIKEN";

	/** テーブル(メール)*/
	private static final String D_TBL_NAME_CC_M_MAIL = "CC_M_MAIL";

	/** SQL定義キー(CH_SELECT_034)*/
	private static final String CH_T_SAIKEN_CH_SELECT_034 = "CH_SELECT_034";

	/** SQL定義キー(CH_SELECT_001)*/
	private static final String CC_M_MAIL_CH_SELECT_001 = "CH_SELECT_001";

	/** テーブルアクセスクラス(債権)*/
	private JBSbatSQLAccess db_CH_T_SAIKEN = null;

	/** テーブルアクセスクラス(メール)*/
	private JBSbatSQLAccess db_CC_M_MAIL = null;
	/**▲▲▲▲▲▲ツールから生成した宣言です 終了▲▲▲▲▲▲*/
	
	/** 債権年月 */
	private static final String SAIKEN_YM = "SAIKEN_YM";
	
	/** 対応記録タイトル */
	private static final String TAIO_KIROK_TITLE =  "【mineo】利用停止予告メール（引落NG）";
	
	/** メールコード */
	private static final String MAIL_CODE = "CHM1000003";
	
	/** 件数ファイル用カウンター変数 */
	private int counter = 0;
	
	/** 改行コード */
	private static final String LF  = "LF";
	
	/** ファイル括り文字 */
	private static final String SCOPE  = "\"";
	
	/** サービス契約番号 */
	private String svc_kei_no = null;
	
	/** 請求契約番号 */
	private String seiky_kei_no = null;
	
	/** メール宛先 */
	private String sends_mlad = null;
	
	/** メール本文 */
	private String mail_text = null;
	
	/** メール題名 */
	private String mail_title = null;
	
	/** メール送信者名 */
	private String sendm_mlad_dsp_nm = null;
	
	/** メール送信者 */
	private String sendm_mlad = null;
	
	/** メール返信先 */
	private String hnsin_mlad = null;
	
	/** エラーメール返信先 */
	private String err_mlad = null;
	
	// v28.00.02 ADD START
	/** メール本文（編集後） */
	private String make_mail_text = null;
	// v28.00.02 ADD END
	
	/**
	 * 初期処理
	 * @param JBSbatCommonItem commonItem　バッチ共通パラメータ電文
	 * @throws Exception
	 */
	public void initial(JBSbatCommonItem commonItem) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの初期処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した初期化のソースです 開始▼▼▼▼▼▼*/
		// 共通パラメータを設定します
		super.setCommonInfo(commonItem);

		// DBアクセスクラスを生成します
		db_CH_T_SAIKEN = new JBSbatSQLAccess(commonItem, D_TBL_NAME_CH_T_SAIKEN);
		db_CC_M_MAIL = new JBSbatSQLAccess(commonItem, D_TBL_NAME_CC_M_MAIL);

		// メール情報取得
		Object[] setParamMail = {MAIL_CODE, super.opeDate, super.opeDate, super.opeDate};
		this.executeCC_M_MAIL_CH_SELECT_001(setParamMail);
		JBSbatCommonDBInterface resultMail = db_CC_M_MAIL.selectNext();
		
		//メール情報が取得できない場合、エラー出力して処理を終了する
		
		if(resultMail == null)
		{
			String[] msgParam = new String[] { "メール情報", "メールコード（CHM1000003）"};
			throw new JBSbatBusinessException(JPCBatchMessageConstant.ECHB1520CE, msgParam);
		}
		//メール情報の設定
		mail_text = resultMail.getString(JBSbatCC_M_MAIL.MAIL_TEXT);
		mail_title = resultMail.getString(JBSbatCC_M_MAIL.MAIL_TITLE);
		sendm_mlad_dsp_nm = resultMail.getString(JBSbatCC_M_MAIL.SENDM_MLAD_DSP_NM);
		sendm_mlad = resultMail.getString(JBSbatCC_M_MAIL.SENDM_MLAD);
		hnsin_mlad = resultMail.getString(JBSbatCC_M_MAIL.HNSIN_MLAD);
		err_mlad = resultMail.getString(JBSbatCC_M_MAIL.ERR_MLAD);
		
		// 件数ファイル用カウンター変数初期化
		this.counter = 0;
		
		/**▲▲▲▲▲▲ツールから生成した初期化のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの初期処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 主処理
	 * @param inMap　入力電文
	 * @return JBSbatOutputItem　出力情報
	 * @throws Exception
	 */
	public JBSbatOutputItem execute(JBSbatServiceInterfaceMap inMap) throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの主処理を記述してください。▼▼▼▼▼▼*/
		// 入力ファイルの情報がなくなったらメイン処理を実行する
		JBSbatOutputItem outputBean = new JBSbatOutputItem();
		
		//サービス契約番号の取得
		svc_kei_no = inMap.getString(JBSbatCHIFM275.SVC_KEI_NO);
		//債権年月の取得（最古:0、最新:1）
		String saikenYm[] = saikenYmGet(inMap);

		//メール本文の作成
		makeMailText(saikenYm);
		
		//請求契約番号の取得
		seiky_kei_no = inMap.getString(JBSbatCHIFM275.SEIKY_KEI_NO);
		//料金履歴情報作成
		prcrrkMake(outputBean);
		
		//メール宛先の取得
		sends_mlad = inMap.getString(JBSbatCHIFM275.MINEO_MAIL_ADDRESS);
		//mineo利用停止予告メール送信情報（口振）作成
		mineoriteiMailmake(outputBean);
		
		return outputBean;

	/**▲▲▲▲▲▲業務サービスの主処理を記述してください。▲▲▲▲▲▲*/
	}

	/**
	 * 本文埋め込み編集（年月）
	 * 
	 * @param ym 年月
	 * @return month
	 * @throws Exception
	 */
	private String makeMonth(String ym) throws Exception
	{
		//返却用月
		int month = 0;
		//取得した年月を埋め込み文字用に編集する
		//月の一文字目を取得（10月→"1",09月→"0"）
		month = Integer.parseInt(ym.substring(4, 6));
		 
		return "" + month ;
	}


/**
 * 債権年月取得
 * 
 * @param inMap
 * @return saikenYm
 * @throws Exception
 */
private String[] saikenYmGet(JBSbatServiceInterfaceMap inMap) throws Exception
{
// v28.00.01 MOD START
//	// 入力ファイルより督促番号の取得
//	Object[] setParamtokusokuNo = {inMap.getString(JBSbatCHIFM275.TOKUSOKU_NO)};
	// 入力ファイルより請求契約番号の取得
	Object[] setParamseikykeino = {inMap.getString(JBSbatCHIFM275.SEIKY_KEI_NO)};
// v28.00.01 MOD END
	
	// 債権年月の取得
// v28.00.01 MOD START
//	this.executeCH_T_SAIKEN_CH_SELECT_034(setParamtokusokuNo);
	this.executeCH_T_SAIKEN_CH_SELECT_034(setParamseikykeino);
// v28.00.01 MOD END
	
	//債権年月（最古:0、最新:1）
	String[] saikenYm = new String[2];

	//検索結果を取得
	JBSbatCommonDBInterface saikenInf = db_CH_T_SAIKEN.selectNext();
	
	if(null != saikenInf)
	{
		// 昇順に取得しているので1レコード目が最古年月
		saikenYm[0] = saikenInf.getString(SAIKEN_YM);
		saikenInf = db_CH_T_SAIKEN.selectNext();
	}
	while (null != saikenInf) {
		// 最終レコードを最新年月に格納する
		saikenYm[1] = saikenInf.getString(SAIKEN_YM);

		saikenInf = db_CH_T_SAIKEN.selectNext();
	}
	// v28.00.02 MOD START
//	 //最新年月、最古年月どちらか一方でも取得できなかった場合
//	 if (saikenYm[0] == null || saikenYm[1] == null)
	 //最古年月が取得できなかった場合
	 if (saikenYm[0] == null)
	// v28.00.02 MOD END
	 {
		// ワーニング出力
		String[] msgParam = new String[]{ "債権年月",svc_kei_no };
		super.logPrint.printBusinessErrorLog(JPCBatchMessageConstant.ECHB1530TW, msgParam);
		
		// 次のデータへスキップ。
		throw new JBSbatBusinessError();
	 }
	 return saikenYm;
}

/**
 * メール本文作成
 * 
 * @param saikenYm 
 * @return 
 * @throws Exception
 */
private void makeMailText(String[] saikenYm) throws Exception
{
	 //メール本文の埋め込み文字を設定する
	// 置換文字配列の宣言
	// v28.00.02 MOD START
//	String[] repStringText = new String[6];
//	String[] chgTextNo = {"%1%", "%2%","%3%","%4%","%5%","%6%"};
	String[] repStringText = new String[5];
	String[] chgTextNo = {"%1%", "%2%","%3%","%4%","%5%"};
	// v28.00.02 MOD END

	// v28.00.02 DEL START
//	//上記で取得した債権年月を埋め込み文字用に編集する
//	String old_saikenM = makeMonth(saikenYm[0]);
//	String new_saikenM = makeMonth(saikenYm[1]);
	// v28.00.02 DEL END

	// v28.00.02 ADD START
	//上記で取得した埋め込み文字用債権年月を元にメール埋め込み文言を編集する
	String minoM = makeMinoMonth(saikenYm);
	// v28.00.02 ADD END
	
	//バッチ運用月を埋め込み文字用に編集する
	String opM = makeMonth(super.opeDate);
	
	//置換文字列を格納していく
	// v28.00.02 MOD START
//	repStringText[0] = old_saikenM;
//	repStringText[1] = new_saikenM;
//	repStringText[2] = opM;
//	repStringText[3] = "15";
//	repStringText[4] = opM;
//	repStringText[5] = JBSbatDateUtil.getEndOfMonth(super.opeDate.substring(0, 6));
	repStringText[0] = minoM;
	repStringText[1] = opM;
	repStringText[2] = "15";
	repStringText[3] = opM;
	repStringText[4] = JBSbatDateUtil.getEndOfMonth(super.opeDate.substring(0, 6));
	// v28.00.02 MOD END
	
	//メール本文を作成する
	// v28.00.02 MOD START
//	mail_text =  repTextDataString(mail_text, repStringText, chgTextNo);
	make_mail_text =  repTextDataString(mail_text, repStringText, chgTextNo);
	// v28.00.02 MOD END
}

// v28.00.02 ADD START

/**
 * 本文埋め込み編集（未納年月）
 * 
 * @param ym 年月
 * @return month
 * @throws Exception
 */
private String makeMinoMonth(String[] saikenYm) throws Exception
{
	StringBuilder sb = new StringBuilder();
	
	sb.append(makeMonth(saikenYm[0]));
	sb.append("月");

	if(saikenYm[1] != null)
	{
		sb.append("および");
		sb.append(makeMonth(saikenYm[1]));
		sb.append("月");
	}

	return sb.toString();
	
}
//v28.00.02 ADD END

/**
 * 料金履歴情報作成
 * 
 * @param outputBean
 * @return 
 * @throws Exception
 */
private void prcrrkMake(JBSbatOutputItem outputBean) throws Exception
{
	//全項目つめる
	// 料金対応記録送信出力用MAP
	JBSbatServiceInterfaceMap outMap = new JBSbatServiceInterfaceMap();

	// 01.請求契約番号
	outMap.set(JBSbatCHIFM096.SEIKY_KEI_NO, 				seiky_kei_no);
	// 02.サービス契約番号
	outMap.set(JBSbatCHIFM096.SVC_KEI_NO, 					null);
	// 03.対応年月日時分秒
	outMap.set(JBSbatCHIFM096.TAIO_DTM, 					super.opeDate.concat(JCCBatCommon.getSysDateTimeStamp().substring(8)));
	// 04.	 <- "133"（mineo督促処理（バッチ））
	outMap.set(JBSbatCHIFM096.PRC_TAIO_KIROK_SBT_CD, 		"133");
	// 05.料金対応記録種別詳細コード <- "2713"（mineo利用停止予告済）
	outMap.set(JBSbatCHIFM096.PRC_TAIO_KIROK_SBT_DTL_CD, 	"2713");
	// 06.記録対象年月
	outMap.set(JBSbatCHIFM096.KIROK_TG_YM, 					null);
	// 07.督促番号
	outMap.set(JBSbatCHIFM096.TOKUSOKU_NO, 					null);
	// 08.督促異動番号
	outMap.set(JBSbatCHIFM096.TOKUSOKU_IDO_NO, 				null);
	// 09.請求番号
	outMap.set(JBSbatCHIFM096.SEIKY_NO,						null);
	// 10.金庫番号
	outMap.set(JBSbatCHIFM096.KNK_NO, 						null);
	// 11.債権番号
	outMap.set(JBSbatCHIFM096.SAIKEN_NO, 					null);
	// 12.入金番号
	outMap.set(JBSbatCHIFM096.NYUKIN_NO, 					null);
	// 13.電子ファイル管理番号
	outMap.set(JBSbatCHIFM096.EFILE_KANRI_NO, 				null);
	// 14.対応履歴連動対象フラグ<- "0"(対応履歴連動非対象)
	outMap.set(JBSbatCHIFM096.TAIORRKI_RENDO_TG_FLG, 		"0");
	// 15.変更前金額
	outMap.set(JBSbatCHIFM096.AMNT_CHBF, 					null);
	// 16.変更後金額
	outMap.set(JBSbatCHIFM096.AMNT_CHAF, 					null);
	// 17.変更前督促ステータス
	outMap.set(JBSbatCHIFM096.TOKUSOKU_STAT_CHBF, 			null);
	// 18.変更後督促ステータス
	outMap.set(JBSbatCHIFM096.TOKUSOKU_STAT_CHAF, 			null);
	// 19.変更前料金グループコード
	outMap.set(JBSbatCHIFM096.PRC_GRP_CD_CHBF, 				null);
	// 20.変更後料金グループコード
	outMap.set(JBSbatCHIFM096.PRC_GRP_CD_CHAF, 				null);
	// 21.変更前料金コースコード
	outMap.set(JBSbatCHIFM096.PCRS_CD_CHBF, 				null);
	// 22.変更後料金コースコード
	outMap.set(JBSbatCHIFM096.PCRS_CD_CHAF, 				null);
	// 23.変更前料金サービスコード
	outMap.set(JBSbatCHIFM096.PRC_SVC_CD_CHBF, 				null);
	// 24.変更後料金サービスコード
	outMap.set(JBSbatCHIFM096.PRC_SVC_CD_CHAF, 				null);
	// 25.変更前金庫料金項目コード
	outMap.set(JBSbatCHIFM096.KNK_PRC_KMK_CD_CHBF, 			null);
	// 26.変更後金庫料金項目コード
	outMap.set(JBSbatCHIFM096.KNK_PRC_KMK_CD_CHAF, 			null);
	// 27.督促メールパターン <- "A3"（２ヶ月引落NGによるmineo利用停止予告メール）
	outMap.set(JBSbatCHIFM096.TOKUSOKU_ML_PTN_CD, 			"A3");
	// 28.変更前補償費扱いフラグ
	outMap.set(JBSbatCHIFM096.COMPENSATION_FLG_CHBF, 		null);
	// 29.変更後補償費扱いフラグ
	outMap.set(JBSbatCHIFM096.COMPENSATION_FLG_CHAF, 		null);
	// 30.変更前引抜き種別コード
	outMap.set(JBSbatCHIFM096.HKNK_SBT_CD_CHBF, 			null);
	// 31.変更後引抜き種別コード
	outMap.set(JBSbatCHIFM096.HKNK_SBT_CD_CHAF, 			null);
	// 32.記事
	outMap.set(JBSbatCHIFM096.KIJI, 						null);
	// 出力フラグ設定
	outMap.setOutFlg(true);
	outputBean.addOutMapList(outMap);
}

/**
 * mineo利用停止予告メール送信情報（口振）作成
 * 
 * @param outputBean
 * @return 
 * @throws Exception
 */
private void mineoriteiMailmake(JBSbatOutputItem outputBean) throws Exception
{
	//全項目つめる
	// mineo利用停止予告メール送信情報（口振）出力用MAP
	JBSbatServiceInterfaceMap outMap = new JBSbatServiceInterfaceMap();

	// お客様ID <- サービス契約番号
	outMap.set(JBSbatCHIFE518.SVC_KEI_NO, svc_kei_no);
	// メール宛先 <- メール宛先
	outMap.set(JBSbatCHIFE518.SENDS_MLAD, sends_mlad );
	// メール送信者名 <- メール送信者名
	outMap.set(JBSbatCHIFE518.SENDM_MLAD_DSP_NM, sendm_mlad_dsp_nm);
	// メール送信者 <- メール送信者
	outMap.set(JBSbatCHIFE518.SENDM_MLAD, sendm_mlad);
	// メール返信先 <- 返信先メールアドレス
	outMap.set(JBSbatCHIFE518.HNSIN_MLAD, hnsin_mlad);
	// エラーメール返信先 <- エラーメールアドレス
	outMap.set(JBSbatCHIFE518.HNSIN_ERR_MLAD, err_mlad);
	// ＢＣＣ <- スペース
	outMap.set(JBSbatCHIFE518.BCC_MLAD," ");
	//メール題名 <- メール題名
	outMap.set(JBSbatCHIFE518.MAIL_TITLE, mail_title);
	//メール本文 <- メール本文
	// v28.00.02 MOD START
//	outMap.set(JBSbatCHIFE518.MAIL_TEXT, mail_text);
	outMap.set(JBSbatCHIFE518.MAIL_TEXT, make_mail_text);
	// v28.00.02 MOD END
	//対応記録タイトル <- 対応記録タイトル
	outMap.set(JBSbatCHIFE518.TAIO_KIROK_TITLE, TAIO_KIROK_TITLE);
	// 出力フラグ設定
	outMap.setOutFlg(true);
	outputBean.addOutMapList_2(outMap);
	//件数カウントアップ
	this.counter++;
}
	/**
	 * 文字列内の可変文字を置き換える
	 * <p>
	 * </p>
	 * @param textData 可変文字を含む文字列
	 * @param param    変換する文字列
	 * @return 変換結果（改行コード変更後）
	 */
	private String repTextDataString(String textData, String[] param, String[] chgNo)
	{
		for(int i = 0; i < param.length; i++)
		{
			if (param[i] != null)
			{
				textData = textData.replaceFirst(chgNo[i], param[i]);
			}
		}
		
		return textData;
	}
	/**
	 * 業務サービス終了処理
	 * @throws Exception
	 */
	public void terminal() throws Exception
	{
	/**▼▼▼▼▼▼業務サービスの終了処理を記述してください。▼▼▼▼▼▼*/
		/**▼▼▼▼▼▼ツールから生成した終了処理のソースです 開始▼▼▼▼▼▼*/
		
		// 件数ファイルオブジェクト
		JBSbatOutputFileUtil cntFile = null;
		
		try
		{
			// フリーパラメータをチェック
			if(super.freeItem == null || "".equals(super.freeItem))
			{
				// 件数ファイルパラメータ異常
				throw new Exception();
			}
			
			// 件数ファイル作成
			cntFile = new JBSbatOutputFileUtil(super.freeItem);
			cntFile.setEncode(JKKBatConst.SJIS);
			cntFile.setLine(LF);
			cntFile.createWriter();
			StringBuffer sb = new StringBuffer();
			sb.append(SCOPE);
			sb.append(String.format("%05d",this.counter));
			sb.append(SCOPE);
			cntFile.write(sb.toString());
		}
		catch(Exception e)
		{
			// 出力ファイルの作成に失敗
			String rsn = "件数ファイルの作成に失敗（";
			StringBuffer buf = new StringBuffer();
			buf.append("出力件数パス：");
			buf.append(super.freeItem);	
			buf.append("）");
			// エラーを投げる
			throw new JBSbatBusinessException("ECHB1550CE", new String[]{ rsn, buf.toString() });
		}
		finally
		{
			// 件数ファイルオブジェクトを閉じる
			if(cntFile != null)
			{
				// 件数ファイルを閉じる
				cntFile.close();
				cntFile = null;
			}
		}
		// DBアクセスクラスをクローズします
		db_CH_T_SAIKEN.close();
		db_CC_M_MAIL.close();
		/**▲▲▲▲▲▲ツールから生成した終了処理のソースです 終了▲▲▲▲▲▲*/
	/**▲▲▲▲▲▲業務サービスの終了処理を記述してください。▲▲▲▲▲▲*/
	}

	/**▼▼▼▼▼▼ツールから生成したメソッドです 開始▼▼▼▼▼▼*/
	/**
	 * SQLKEY(CH_SELECT_034)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	督促番号
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeCH_T_SAIKEN_CH_SELECT_034(Object[] param) throws Exception
	{
		// バイント変数のリストを生成します
		JBSbatCommonDBInterface paramList = new JBSbatCommonDBInterface();
		paramList.setValue(param[0].toString());

		// DBアクセスを実行します
		db_CH_T_SAIKEN.selectBySqlDefine(paramList, CH_T_SAIKEN_CH_SELECT_034);
	}

	/**
	 * SQLKEY(CH_SELECT_001)でDBアクセスを行います。<br>
	 * <p>
	 * <b>処理フロー</b><br>
	 * <pre>
	 * 1.引数でバイント変数を設定します。<br>
	 *
	 * 2.DBアクセスを実行します。<br>
	 * 
	 * 3.メソッドの呼び出し方です。<br>
	 *		引数:
	 *		param:順にバイント変数の値をparam配列に入れます。バイント変数は以下に説明します。
	 *		 	メールコード
	 *		 	予約適用年月日
	 *		 	メール開始適用年月日
	 *		 	メール終了年月日
	 * </pre>
	 * <p>
	 * @param param バイント変数の値配列。
	 * @throws Exception 業務サービス内で発生した例外全般。
	 */
	private void executeCC_M_MAIL_CH_SELECT_001(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());

		// DBアクセスを実行します
		db_CC_M_MAIL.selectBySqlDefine(paramList, CC_M_MAIL_CH_SELECT_001);
	}
	/**▲▲▲▲▲▲ツールから生成したメソッドです 終了▲▲▲▲▲▲*/
}
