/*******************************************************************************
*	 All Rights reserved,Copyright (c) K-Opticom 
********************************************************************************
*＜プログラム内容＞
*	システム名		：eo顧客基幹システム
*	モジュール名	：JSYejbZM0151KRCK
*	ソースファイル名：JSYejbZM0151KRCK.java
*	作成者			：EK909281
*	日付			：2012年09月05日
*＜機能概要＞
*	関連チェック部品です。
*＜修正履歴＞
*	バージョン	修正日		修正者		修正内容
*	ｖ1.00.00
*
********************************************************************************/

package eo.ejb.cbm.entity;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Timestamp;
import java.text.SimpleDateFormat;
import java.text.ParsePosition;
import com.fujitsu.futurity.model.ejb.common.JSYejbLog;
import com.fujitsu.futurity.model.ejb.common.JSYejbConnection;
import com.fujitsu.futurity.model.ejb.common.StatusCodes;
import com.fujitsu.futurity.model.ejb.common.fw.AgentDispatchContext;
import eo.ejb.common.EventIDList;
import com.fujitsu.futurity.model.ejb.common.fw.KanrenCheckHandler;

import com.fujitsu.futurity.model.base.CAANConnectionMgr;
import com.fujitsu.futurity.model.base.CAANJDBCUtil;
import com.fujitsu.futurity.model.base.CAANMsg;
import com.fujitsu.futurity.model.base.CAANRuntimeException;

/**
 * 業務個別設定組織関連チェッククラスです。
 * ＜メソッド一覧＞
 * invoke
 *	execICR0091D001_2
 *	execICR0111C001_5
 *	execICR0111D001_5
 *	execICR0141C001_3
 *	execICR0141D001_2
 *	execICR0161C001_2
 *	execICR0161D001_2
 *	execICR0231D001_6
 *	execICR0251D001_2
 *	execICR0301D001_2
 *	execICR0411D001_8
 *	execIZM0041C001_7
 *	execIZM0041C001_8
 *	execIZM0041C001_9
 *	execIZM0041D001_7
 *	execIZM0041D001_8
 *	execIZM0041D001_9
 *
 */

public class JSYejbZM0151KRCK implements KanrenCheckHandler {

	/**
	 * コンストラクタ
	 */

	public JSYejbZM0151KRCK() {
	}

	/**
	 * 業務個別設定組織関連チェックを行います。
	 * 
	 * @param inETMsg エンティティ
	 * @param inContext Agentから渡されたAgentDispatchContext
	 */

	public void invoke(CAANMsg inETMsg, AgentDispatchContext inContext) {

		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "call:JSYejbZM0151KRCK.invoke");

		// inETMsgのチェック
		if(inETMsg == null) {
			throw new CAANRuntimeException("inETMsgがnullです。");
		}

		// 振舞IDの取り出し
		String eventID = inETMsg.getString("eventID");
		if(eventID == null) {
			throw new CAANRuntimeException("振舞IDがnullです。");
		}

		// 処理の振り分け
		// イベントの振り分け
		if(eventID.equals(EventIDList.ICR0091D001)){
			/** エスカレーション制御キューBOX登録振舞内部 */
			int Rtn = 0;
			Rtn = execICR0091D001_2(inETMsg, inContext, "EB");

		}else if(eventID.equals(EventIDList.ICR0111C001)){
			/** キューBOX変更振舞内部 */
			int Rtn = 0;
			Rtn = execICR0111C001_5(inETMsg, inContext, "EE");

		}else if(eventID.equals(EventIDList.ICR0111D001)){
			/** キューBOX登録振舞内部 */
			int Rtn = 0;
			Rtn = execICR0111D001_5(inETMsg, inContext, "EE");

		}else if(eventID.equals(EventIDList.ICR0141C001)){
			/** カテゴリー更新振舞内部 */
			int Rtn = 0;
			Rtn = execICR0141C001_3(inETMsg, inContext, "EC");

		}else if(eventID.equals(EventIDList.ICR0141D001)){
			/** カテゴリー登録振舞内部 */
			int Rtn = 0;
			Rtn = execICR0141D001_2(inETMsg, inContext, "EB");

		}else if(eventID.equals(EventIDList.ICR0161C001)){
			/** クエリ更新振舞内部 */
			int Rtn = 0;
			Rtn = execICR0161C001_2(inETMsg, inContext, "EB");

		}else if(eventID.equals(EventIDList.ICR0161D001)){
			/** クエリ登録振舞内部 */
			int Rtn = 0;
			Rtn = execICR0161D001_2(inETMsg, inContext, "EB");

		}else if(eventID.equals(EventIDList.ICR0231D001)){
			/** 対応履歴電子ファイル管理登録振舞内部 */
			int Rtn = 0;
			Rtn = execICR0231D001_6(inETMsg, inContext, "EF");

		}else if(eventID.equals(EventIDList.ICR0251D001)){
			/** 資料送付グループ_業務個別設定組織登録振舞内部 */
			int Rtn = 0;
			Rtn = execICR0251D001_2(inETMsg, inContext, "EB");

		}else if(eventID.equals(EventIDList.ICR0301D001)){
			/** 業務個別設定組織別タブ制御登録振舞内部 */
			int Rtn = 0;
			Rtn = execICR0301D001_2(inETMsg, inContext, "EB");

		}else if(eventID.equals(EventIDList.ICR0411D001)){
			/** 業務個別設定組織別初期値制御登録振舞内部 */
			int Rtn = 0;
			Rtn = execICR0411D001_8(inETMsg, inContext, "EG");

		}else if(eventID.equals(EventIDList.IZM0041C001)){
			/** 権限グループ変更振舞内部 */
			int Rtn = 0;
			Rtn = execIZM0041C001_7(inETMsg, inContext, "EG");

			if(Rtn <= StatusCodes.WARNING){
				Rtn = execIZM0041C001_8(inETMsg, inContext, "EH");
			}

			if(Rtn <= StatusCodes.WARNING){
				Rtn = execIZM0041C001_9(inETMsg, inContext, "EI");
			}

		}else if(eventID.equals(EventIDList.IZM0041D001)){
			/** 権限グループ登録振舞内部 */
			int Rtn = 0;
			Rtn = execIZM0041D001_7(inETMsg, inContext, "EG");

			if(Rtn <= StatusCodes.WARNING){
				Rtn = execIZM0041D001_8(inETMsg, inContext, "EH");
			}

			if(Rtn <= StatusCodes.WARNING){
				Rtn = execIZM0041D001_9(inETMsg, inContext, "EI");
			}

		}

		JSYejbLog.println(JSYejbLog.DEBUG, getClass(), "end:JSYejbZM0151KRCK.invoke");

	}

	/**
	 * ICR0091D001_制約ＮＯ2チェック
	 *
	 * @param inETMsg チェック対象のETMsg(CR0091ETMsg)
	 * @param inContext Agentから渡されたAgentDispatchContext
	 * @param errFlag ERRフラグ
	 * @return int チェック結果
	 */
	private int execICR0091D001_2(CAANMsg inETMsg, AgentDispatchContext inContext, String errFlag){

		// ステータス
		int rtn = 0;

		Connection con = JSYejbConnection.getConnection(ZM0151ETMsg.getTableName());

		PreparedStatement pstmtQuery = null;
		ResultSet rsltQuery = null;
		StringBuffer sqlQuery = new StringBuffer();

		try{

			// チェック条件定数
			// ＳＱＬ引数定義
			String joken1_2 = null;
			if(!inETMsg.isNull(CR0091ETMsg.WKKBT_ORG_CD)){
				joken1_2 = new String(inETMsg.getObject(CR0091ETMsg.WKKBT_ORG_CD).toString());
			}

			String joken3_2 = "0";
			String joken4_2 = null;
			if(!inETMsg.isNull(CR0091ETMsg.OPERATEDATE)){
				joken4_2 = new String(inETMsg.getObject(CR0091ETMsg.OPERATEDATE).toString());
			}

			String joken5_2 = null;
			if(!inETMsg.isNull(CR0091ETMsg.OPERATEDATE)){
				joken5_2 = new String(inETMsg.getObject(CR0091ETMsg.OPERATEDATE).toString());
			}

			// 条件文定義
			String joken_1 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_CD);
			if(joken1_2 == null){
				joken_1 += " IS NULL ";
			}else{
				joken_1 += " = ? ";
			}

			String joken_3 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.MK_FLG);
			if(joken3_2 == null){
				joken_3 += " IS NULL ";
			}else{
				joken_3 += " = ? ";
			}

			String joken_4 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TSTAYMD);
			if(joken4_2 == null){
				joken_4 += " IS NULL ";
			}else{
				joken_4 += " <= ? ";
			}

			String joken_5 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TENDYMD);
			if(joken5_2 == null){
				joken_5 += " IS NULL ";
			}else{
				joken_5 += " >= ? ";
			}

			// チェック条件
			if (!inETMsg.isNull(CR0091ETMsg.WKKBT_ORG_CD)) { 

				// ＳＱＬ文の組み立て
				sqlQuery.append("SELECT COUNT(*) CNT FROM ").append(ZM0151ETMsg.getTableName()).append(" WHERE ")
					.append("(" + "(" + "(" + joken_1 + " AND " + joken_3 + " ) " + " AND " + joken_4 + " ) " + " AND " + joken_5 + " ) ");

				// ＳＱＬ文の解析
				pstmtQuery = con.prepareStatement(sqlQuery.toString());

				// パラメータの設定
				int para_idx = 1;
				if(joken1_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken1_2);
				}
				if(joken3_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken3_2);
				}
				if(joken4_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken4_2);
				}
				if(joken5_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken5_2);
				}

				// ＳＱＬ文の実行
				rsltQuery = pstmtQuery.executeQuery();

				if(rsltQuery.next()){
				// 判定条件
					if(!(rsltQuery.getLong("CNT")>0)){
						inETMsg.set(CR0091ETMsg.WKKBT_ORG_CD_ERR, errFlag);
						if("W".equals(errFlag.substring(0,1))){
							rtn = StatusCodes.WARNING;
						} else {
							rtn = StatusCodes.RELATION_ERR;
						}
					}
				}

			}

		} catch(SQLException e) {
			inETMsg.set(CR0091ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
			throw new CAANRuntimeException(e);
		} finally {
			// このメソッドで確保した資源の解放
			try {
				if(rsltQuery != null) {
					rsltQuery.close();
				}
				if(pstmtQuery != null) {
					pstmtQuery.close();
				}
				if(con != null) {
					CAANConnectionMgr.getInstance().close(con);
				}
			} catch(SQLException e) {
				inETMsg.set(CR0091ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
				throw new CAANRuntimeException(e);
			}
		}
		
		// ステータスのセット
		if (rtn > inETMsg.getInt(CR0091ETMsg.STATUS)) {
			inETMsg.set(CR0091ETMsg.STATUS, rtn);
		}

		return rtn;

	}

	/**
	 * ICR0111C001_制約ＮＯ5チェック
	 *
	 * @param inETMsg チェック対象のETMsg(CR0111ETMsg)
	 * @param inContext Agentから渡されたAgentDispatchContext
	 * @param errFlag ERRフラグ
	 * @return int チェック結果
	 */
	private int execICR0111C001_5(CAANMsg inETMsg, AgentDispatchContext inContext, String errFlag){

		// ステータス
		int rtn = 0;

		Connection con = JSYejbConnection.getConnection(ZM0151ETMsg.getTableName());

		PreparedStatement pstmtQuery = null;
		ResultSet rsltQuery = null;
		StringBuffer sqlQuery = new StringBuffer();

		try{

			// チェック条件定数
			// ＳＱＬ引数定義
			String joken1_2 = null;
			if(!inETMsg.isNull(CR0111ETMsg.WKKBT_ORG_CD)){
				joken1_2 = new String(inETMsg.getObject(CR0111ETMsg.WKKBT_ORG_CD).toString());
			}

			String joken2_2 = "0";
			String joken4_2 = null;
			if(!inETMsg.isNull(CR0111ETMsg.OPERATEDATE)){
				joken4_2 = new String(inETMsg.getObject(CR0111ETMsg.OPERATEDATE).toString());
			}

			String joken5_2 = null;
			if(!inETMsg.isNull(CR0111ETMsg.OPERATEDATE)){
				joken5_2 = new String(inETMsg.getObject(CR0111ETMsg.OPERATEDATE).toString());
			}

			// 条件文定義
			String joken_1 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_CD);
			if(joken1_2 == null){
				joken_1 += " IS NULL ";
			}else{
				joken_1 += " = ? ";
			}

			String joken_2 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.MK_FLG);
			if(joken2_2 == null){
				joken_2 += " IS NULL ";
			}else{
				joken_2 += " = ? ";
			}

			String joken_4 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TSTAYMD);
			if(joken4_2 == null){
				joken_4 += " IS NULL ";
			}else{
				joken_4 += " <= ? ";
			}

			String joken_5 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TENDYMD);
			if(joken5_2 == null){
				joken_5 += " IS NULL ";
			}else{
				joken_5 += " >= ? ";
			}

			// チェック条件
			if (!inETMsg.isNull(CR0111ETMsg.WKKBT_ORG_CD)) { 

				// ＳＱＬ文の組み立て
				sqlQuery.append("SELECT COUNT(*) CNT FROM ").append(ZM0151ETMsg.getTableName()).append(" WHERE ")
					.append("(" + "(" + "(" + joken_1 + " AND " + joken_2 + " ) " + " AND " + joken_4 + " ) " + " AND " + joken_5 + " ) ");

				// ＳＱＬ文の解析
				pstmtQuery = con.prepareStatement(sqlQuery.toString());

				// パラメータの設定
				int para_idx = 1;
				if(joken1_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken1_2);
				}
				if(joken2_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken2_2);
				}
				if(joken4_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken4_2);
				}
				if(joken5_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken5_2);
				}

				// ＳＱＬ文の実行
				rsltQuery = pstmtQuery.executeQuery();

				if(rsltQuery.next()){
				// 判定条件
					if(!(rsltQuery.getLong("CNT")>0)){
						inETMsg.set(CR0111ETMsg.WKKBT_ORG_CD_ERR, errFlag);
						if("W".equals(errFlag.substring(0,1))){
							rtn = StatusCodes.WARNING;
						} else {
							rtn = StatusCodes.RELATION_ERR;
						}
					}
				}

			}

		} catch(SQLException e) {
			inETMsg.set(CR0111ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
			throw new CAANRuntimeException(e);
		} finally {
			// このメソッドで確保した資源の解放
			try {
				if(rsltQuery != null) {
					rsltQuery.close();
				}
				if(pstmtQuery != null) {
					pstmtQuery.close();
				}
				if(con != null) {
					CAANConnectionMgr.getInstance().close(con);
				}
			} catch(SQLException e) {
				inETMsg.set(CR0111ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
				throw new CAANRuntimeException(e);
			}
		}
		
		// ステータスのセット
		if (rtn > inETMsg.getInt(CR0111ETMsg.STATUS)) {
			inETMsg.set(CR0111ETMsg.STATUS, rtn);
		}

		return rtn;

	}

	/**
	 * ICR0111D001_制約ＮＯ5チェック
	 *
	 * @param inETMsg チェック対象のETMsg(CR0111ETMsg)
	 * @param inContext Agentから渡されたAgentDispatchContext
	 * @param errFlag ERRフラグ
	 * @return int チェック結果
	 */
	private int execICR0111D001_5(CAANMsg inETMsg, AgentDispatchContext inContext, String errFlag){

		// ステータス
		int rtn = 0;

		Connection con = JSYejbConnection.getConnection(ZM0151ETMsg.getTableName());

		PreparedStatement pstmtQuery = null;
		ResultSet rsltQuery = null;
		StringBuffer sqlQuery = new StringBuffer();

		try{

			// チェック条件定数
			// ＳＱＬ引数定義
			String joken1_2 = null;
			if(!inETMsg.isNull(CR0111ETMsg.WKKBT_ORG_CD)){
				joken1_2 = new String(inETMsg.getObject(CR0111ETMsg.WKKBT_ORG_CD).toString());
			}

			String joken2_2 = "0";
			String joken3_2 = null;
			if(!inETMsg.isNull(CR0111ETMsg.OPERATEDATE)){
				joken3_2 = new String(inETMsg.getObject(CR0111ETMsg.OPERATEDATE).toString());
			}

			String joken4_2 = null;
			if(!inETMsg.isNull(CR0111ETMsg.OPERATEDATE)){
				joken4_2 = new String(inETMsg.getObject(CR0111ETMsg.OPERATEDATE).toString());
			}

			// 条件文定義
			String joken_1 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_CD);
			if(joken1_2 == null){
				joken_1 += " IS NULL ";
			}else{
				joken_1 += " = ? ";
			}

			String joken_2 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.MK_FLG);
			if(joken2_2 == null){
				joken_2 += " IS NULL ";
			}else{
				joken_2 += " = ? ";
			}

			String joken_3 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TSTAYMD);
			if(joken3_2 == null){
				joken_3 += " IS NULL ";
			}else{
				joken_3 += " <= ? ";
			}

			String joken_4 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TENDYMD);
			if(joken4_2 == null){
				joken_4 += " IS NULL ";
			}else{
				joken_4 += " >= ? ";
			}

			// チェック条件
			if (!inETMsg.isNull(CR0111ETMsg.WKKBT_ORG_CD)) { 

				// ＳＱＬ文の組み立て
				sqlQuery.append("SELECT COUNT(*) CNT FROM ").append(ZM0151ETMsg.getTableName()).append(" WHERE ")
					.append("(" + "(" + "(" + joken_1 + " AND " + joken_2 + " ) " + " AND " + joken_3 + " ) " + " AND " + joken_4 + " ) ");

				// ＳＱＬ文の解析
				pstmtQuery = con.prepareStatement(sqlQuery.toString());

				// パラメータの設定
				int para_idx = 1;
				if(joken1_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken1_2);
				}
				if(joken2_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken2_2);
				}
				if(joken3_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken3_2);
				}
				if(joken4_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken4_2);
				}

				// ＳＱＬ文の実行
				rsltQuery = pstmtQuery.executeQuery();

				if(rsltQuery.next()){
				// 判定条件
					if(!(rsltQuery.getLong("CNT")>0)){
						inETMsg.set(CR0111ETMsg.WKKBT_ORG_CD_ERR, errFlag);
						if("W".equals(errFlag.substring(0,1))){
							rtn = StatusCodes.WARNING;
						} else {
							rtn = StatusCodes.RELATION_ERR;
						}
					}
				}

			}

		} catch(SQLException e) {
			inETMsg.set(CR0111ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
			throw new CAANRuntimeException(e);
		} finally {
			// このメソッドで確保した資源の解放
			try {
				if(rsltQuery != null) {
					rsltQuery.close();
				}
				if(pstmtQuery != null) {
					pstmtQuery.close();
				}
				if(con != null) {
					CAANConnectionMgr.getInstance().close(con);
				}
			} catch(SQLException e) {
				inETMsg.set(CR0111ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
				throw new CAANRuntimeException(e);
			}
		}
		
		// ステータスのセット
		if (rtn > inETMsg.getInt(CR0111ETMsg.STATUS)) {
			inETMsg.set(CR0111ETMsg.STATUS, rtn);
		}

		return rtn;

	}

	/**
	 * ICR0141C001_制約ＮＯ3チェック
	 *
	 * @param inETMsg チェック対象のETMsg(CR0141ETMsg)
	 * @param inContext Agentから渡されたAgentDispatchContext
	 * @param errFlag ERRフラグ
	 * @return int チェック結果
	 */
	private int execICR0141C001_3(CAANMsg inETMsg, AgentDispatchContext inContext, String errFlag){

		// ステータス
		int rtn = 0;

		Connection con = JSYejbConnection.getConnection(ZM0151ETMsg.getTableName());

		PreparedStatement pstmtQuery = null;
		ResultSet rsltQuery = null;
		StringBuffer sqlQuery = new StringBuffer();

		try{

			// チェック条件定数
			// ＳＱＬ引数定義
			String joken1_2 = null;
			if(!inETMsg.isNull(CR0141ETMsg.WKKBT_ORG_CD)){
				joken1_2 = new String(inETMsg.getObject(CR0141ETMsg.WKKBT_ORG_CD).toString());
			}

			String joken3_2 = "0";
			String joken4_2 = null;
			if(!inETMsg.isNull(CR0141ETMsg.OPERATEDATE)){
				joken4_2 = new String(inETMsg.getObject(CR0141ETMsg.OPERATEDATE).toString());
			}

			String joken5_2 = null;
			if(!inETMsg.isNull(CR0141ETMsg.OPERATEDATE)){
				joken5_2 = new String(inETMsg.getObject(CR0141ETMsg.OPERATEDATE).toString());
			}

			// 条件文定義
			String joken_1 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_CD);
			if(joken1_2 == null){
				joken_1 += " IS NULL ";
			}else{
				joken_1 += " = ? ";
			}

			String joken_3 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.MK_FLG);
			if(joken3_2 == null){
				joken_3 += " IS NULL ";
			}else{
				joken_3 += " = ? ";
			}

			String joken_4 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TSTAYMD);
			if(joken4_2 == null){
				joken_4 += " IS NULL ";
			}else{
				joken_4 += " <= ? ";
			}

			String joken_5 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TENDYMD);
			if(joken5_2 == null){
				joken_5 += " IS NULL ";
			}else{
				joken_5 += " >= ? ";
			}

			// チェック条件
			if (!inETMsg.isNull(CR0141ETMsg.WKKBT_ORG_CD)) { 

				// ＳＱＬ文の組み立て
				sqlQuery.append("SELECT COUNT(*) CNT FROM ").append(ZM0151ETMsg.getTableName()).append(" WHERE ")
					.append("(" + "(" + "(" + joken_1 + " AND " + joken_3 + " ) " + " AND " + joken_4 + " ) " + " AND " + joken_5 + " ) ");

				// ＳＱＬ文の解析
				pstmtQuery = con.prepareStatement(sqlQuery.toString());

				// パラメータの設定
				int para_idx = 1;
				if(joken1_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken1_2);
				}
				if(joken3_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken3_2);
				}
				if(joken4_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken4_2);
				}
				if(joken5_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken5_2);
				}

				// ＳＱＬ文の実行
				rsltQuery = pstmtQuery.executeQuery();

				if(rsltQuery.next()){
				// 判定条件
					if(!(rsltQuery.getLong("CNT")>0)){
						inETMsg.set(CR0141ETMsg.WKKBT_ORG_CD_ERR, errFlag);
						if("W".equals(errFlag.substring(0,1))){
							rtn = StatusCodes.WARNING;
						} else {
							rtn = StatusCodes.RELATION_ERR;
						}
					}
				}

			}

		} catch(SQLException e) {
			inETMsg.set(CR0141ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
			throw new CAANRuntimeException(e);
		} finally {
			// このメソッドで確保した資源の解放
			try {
				if(rsltQuery != null) {
					rsltQuery.close();
				}
				if(pstmtQuery != null) {
					pstmtQuery.close();
				}
				if(con != null) {
					CAANConnectionMgr.getInstance().close(con);
				}
			} catch(SQLException e) {
				inETMsg.set(CR0141ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
				throw new CAANRuntimeException(e);
			}
		}
		
		// ステータスのセット
		if (rtn > inETMsg.getInt(CR0141ETMsg.STATUS)) {
			inETMsg.set(CR0141ETMsg.STATUS, rtn);
		}

		return rtn;

	}

	/**
	 * ICR0141D001_制約ＮＯ2チェック
	 *
	 * @param inETMsg チェック対象のETMsg(CR0141ETMsg)
	 * @param inContext Agentから渡されたAgentDispatchContext
	 * @param errFlag ERRフラグ
	 * @return int チェック結果
	 */
	private int execICR0141D001_2(CAANMsg inETMsg, AgentDispatchContext inContext, String errFlag){

		// ステータス
		int rtn = 0;

		Connection con = JSYejbConnection.getConnection(ZM0151ETMsg.getTableName());

		PreparedStatement pstmtQuery = null;
		ResultSet rsltQuery = null;
		StringBuffer sqlQuery = new StringBuffer();

		try{

			// チェック条件定数
			// ＳＱＬ引数定義
			String joken1_2 = null;
			if(!inETMsg.isNull(CR0141ETMsg.WKKBT_ORG_CD)){
				joken1_2 = new String(inETMsg.getObject(CR0141ETMsg.WKKBT_ORG_CD).toString());
			}

			String joken3_2 = "0";
			String joken4_2 = null;
			if(!inETMsg.isNull(CR0141ETMsg.OPERATEDATE)){
				joken4_2 = new String(inETMsg.getObject(CR0141ETMsg.OPERATEDATE).toString());
			}

			String joken5_2 = null;
			if(!inETMsg.isNull(CR0141ETMsg.OPERATEDATE)){
				joken5_2 = new String(inETMsg.getObject(CR0141ETMsg.OPERATEDATE).toString());
			}

			// 条件文定義
			String joken_1 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_CD);
			if(joken1_2 == null){
				joken_1 += " IS NULL ";
			}else{
				joken_1 += " = ? ";
			}

			String joken_3 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.MK_FLG);
			if(joken3_2 == null){
				joken_3 += " IS NULL ";
			}else{
				joken_3 += " = ? ";
			}

			String joken_4 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TSTAYMD);
			if(joken4_2 == null){
				joken_4 += " IS NULL ";
			}else{
				joken_4 += " <= ? ";
			}

			String joken_5 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TENDYMD);
			if(joken5_2 == null){
				joken_5 += " IS NULL ";
			}else{
				joken_5 += " >= ? ";
			}

			// チェック条件
			if (!inETMsg.isNull(CR0141ETMsg.WKKBT_ORG_CD)) { 

				// ＳＱＬ文の組み立て
				sqlQuery.append("SELECT COUNT(*) CNT FROM ").append(ZM0151ETMsg.getTableName()).append(" WHERE ")
					.append("(" + "(" + "(" + joken_1 + " AND " + joken_3 + " ) " + " AND " + joken_4 + " ) " + " AND " + joken_5 + " ) ");

				// ＳＱＬ文の解析
				pstmtQuery = con.prepareStatement(sqlQuery.toString());

				// パラメータの設定
				int para_idx = 1;
				if(joken1_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken1_2);
				}
				if(joken3_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken3_2);
				}
				if(joken4_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken4_2);
				}
				if(joken5_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken5_2);
				}

				// ＳＱＬ文の実行
				rsltQuery = pstmtQuery.executeQuery();

				if(rsltQuery.next()){
				// 判定条件
					if(!(rsltQuery.getLong("CNT")>0)){
						inETMsg.set(CR0141ETMsg.WKKBT_ORG_CD_ERR, errFlag);
						if("W".equals(errFlag.substring(0,1))){
							rtn = StatusCodes.WARNING;
						} else {
							rtn = StatusCodes.RELATION_ERR;
						}
					}
				}

			}

		} catch(SQLException e) {
			inETMsg.set(CR0141ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
			throw new CAANRuntimeException(e);
		} finally {
			// このメソッドで確保した資源の解放
			try {
				if(rsltQuery != null) {
					rsltQuery.close();
				}
				if(pstmtQuery != null) {
					pstmtQuery.close();
				}
				if(con != null) {
					CAANConnectionMgr.getInstance().close(con);
				}
			} catch(SQLException e) {
				inETMsg.set(CR0141ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
				throw new CAANRuntimeException(e);
			}
		}
		
		// ステータスのセット
		if (rtn > inETMsg.getInt(CR0141ETMsg.STATUS)) {
			inETMsg.set(CR0141ETMsg.STATUS, rtn);
		}

		return rtn;

	}

	/**
	 * ICR0161C001_制約ＮＯ2チェック
	 *
	 * @param inETMsg チェック対象のETMsg(CR0161ETMsg)
	 * @param inContext Agentから渡されたAgentDispatchContext
	 * @param errFlag ERRフラグ
	 * @return int チェック結果
	 */
	private int execICR0161C001_2(CAANMsg inETMsg, AgentDispatchContext inContext, String errFlag){

		// ステータス
		int rtn = 0;

		Connection con = JSYejbConnection.getConnection(ZM0151ETMsg.getTableName());

		PreparedStatement pstmtQuery = null;
		ResultSet rsltQuery = null;
		StringBuffer sqlQuery = new StringBuffer();

		try{

			// チェック条件定数
			// ＳＱＬ引数定義
			String joken1_2 = null;
			if(!inETMsg.isNull(CR0161ETMsg.WKKBT_ORG_CD)){
				joken1_2 = new String(inETMsg.getObject(CR0161ETMsg.WKKBT_ORG_CD).toString());
			}

			String joken3_2 = null;
			if(!inETMsg.isNull(CR0161ETMsg.OPERATEDATE)){
				joken3_2 = new String(inETMsg.getObject(CR0161ETMsg.OPERATEDATE).toString());
			}

			String joken4_2 = null;
			if(!inETMsg.isNull(CR0161ETMsg.OPERATEDATE)){
				joken4_2 = new String(inETMsg.getObject(CR0161ETMsg.OPERATEDATE).toString());
			}

			String joken5_2 = "0";
			// 条件文定義
			String joken_1 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_CD);
			if(joken1_2 == null){
				joken_1 += " IS NULL ";
			}else{
				joken_1 += " = ? ";
			}

			String joken_3 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TSTAYMD);
			if(joken3_2 == null){
				joken_3 += " IS NULL ";
			}else{
				joken_3 += " <= ? ";
			}

			String joken_4 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TENDYMD);
			if(joken4_2 == null){
				joken_4 += " IS NULL ";
			}else{
				joken_4 += " >= ? ";
			}

			String joken_5 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.MK_FLG);
			if(joken5_2 == null){
				joken_5 += " IS NULL ";
			}else{
				joken_5 += " = ? ";
			}

			// チェック条件
			if (!inETMsg.isNull(CR0161ETMsg.WKKBT_ORG_CD)) { 

				// ＳＱＬ文の組み立て
				sqlQuery.append("SELECT COUNT(*) CNT FROM ").append(ZM0151ETMsg.getTableName()).append(" WHERE ")
					.append("(" + "(" + "(" + joken_1 + " AND " + joken_3 + " ) " + " AND " + joken_4 + " ) " + " AND " + joken_5 + " ) ");

				// ＳＱＬ文の解析
				pstmtQuery = con.prepareStatement(sqlQuery.toString());

				// パラメータの設定
				int para_idx = 1;
				if(joken1_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken1_2);
				}
				if(joken3_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken3_2);
				}
				if(joken4_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken4_2);
				}
				if(joken5_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken5_2);
				}

				// ＳＱＬ文の実行
				rsltQuery = pstmtQuery.executeQuery();

				if(rsltQuery.next()){
				// 判定条件
					if(!(rsltQuery.getLong("CNT")>0)){
						inETMsg.set(CR0161ETMsg.WKKBT_ORG_CD_ERR, errFlag);
						if("W".equals(errFlag.substring(0,1))){
							rtn = StatusCodes.WARNING;
						} else {
							rtn = StatusCodes.RELATION_ERR;
						}
					}
				}

			}

		} catch(SQLException e) {
			inETMsg.set(CR0161ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
			throw new CAANRuntimeException(e);
		} finally {
			// このメソッドで確保した資源の解放
			try {
				if(rsltQuery != null) {
					rsltQuery.close();
				}
				if(pstmtQuery != null) {
					pstmtQuery.close();
				}
				if(con != null) {
					CAANConnectionMgr.getInstance().close(con);
				}
			} catch(SQLException e) {
				inETMsg.set(CR0161ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
				throw new CAANRuntimeException(e);
			}
		}
		
		// ステータスのセット
		if (rtn > inETMsg.getInt(CR0161ETMsg.STATUS)) {
			inETMsg.set(CR0161ETMsg.STATUS, rtn);
		}

		return rtn;

	}

	/**
	 * ICR0161D001_制約ＮＯ2チェック
	 *
	 * @param inETMsg チェック対象のETMsg(CR0161ETMsg)
	 * @param inContext Agentから渡されたAgentDispatchContext
	 * @param errFlag ERRフラグ
	 * @return int チェック結果
	 */
	private int execICR0161D001_2(CAANMsg inETMsg, AgentDispatchContext inContext, String errFlag){

		// ステータス
		int rtn = 0;

		Connection con = JSYejbConnection.getConnection(ZM0151ETMsg.getTableName());

		PreparedStatement pstmtQuery = null;
		ResultSet rsltQuery = null;
		StringBuffer sqlQuery = new StringBuffer();

		try{

			// チェック条件定数
			// ＳＱＬ引数定義
			String joken1_2 = null;
			if(!inETMsg.isNull(CR0161ETMsg.WKKBT_ORG_CD)){
				joken1_2 = new String(inETMsg.getObject(CR0161ETMsg.WKKBT_ORG_CD).toString());
			}

			String joken2_2 = "0";
			String joken3_2 = null;
			if(!inETMsg.isNull(CR0161ETMsg.OPERATEDATE)){
				joken3_2 = new String(inETMsg.getObject(CR0161ETMsg.OPERATEDATE).toString());
			}

			String joken4_2 = null;
			if(!inETMsg.isNull(CR0161ETMsg.OPERATEDATE)){
				joken4_2 = new String(inETMsg.getObject(CR0161ETMsg.OPERATEDATE).toString());
			}

			// 条件文定義
			String joken_1 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_CD);
			if(joken1_2 == null){
				joken_1 += " IS NULL ";
			}else{
				joken_1 += " = ? ";
			}

			String joken_2 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.MK_FLG);
			if(joken2_2 == null){
				joken_2 += " IS NULL ";
			}else{
				joken_2 += " = ? ";
			}

			String joken_3 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TSTAYMD);
			if(joken3_2 == null){
				joken_3 += " IS NULL ";
			}else{
				joken_3 += " <= ? ";
			}

			String joken_4 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TENDYMD);
			if(joken4_2 == null){
				joken_4 += " IS NULL ";
			}else{
				joken_4 += " >= ? ";
			}

			// チェック条件
			if (!inETMsg.isNull(CR0161ETMsg.WKKBT_ORG_CD)) { 

				// ＳＱＬ文の組み立て
				sqlQuery.append("SELECT COUNT(*) CNT FROM ").append(ZM0151ETMsg.getTableName()).append(" WHERE ")
					.append("(" + "(" + "(" + joken_1 + " AND " + joken_2 + " ) " + " AND " + joken_3 + " ) " + " AND " + joken_4 + " ) ");

				// ＳＱＬ文の解析
				pstmtQuery = con.prepareStatement(sqlQuery.toString());

				// パラメータの設定
				int para_idx = 1;
				if(joken1_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken1_2);
				}
				if(joken2_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken2_2);
				}
				if(joken3_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken3_2);
				}
				if(joken4_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken4_2);
				}

				// ＳＱＬ文の実行
				rsltQuery = pstmtQuery.executeQuery();

				if(rsltQuery.next()){
				// 判定条件
					if(!(rsltQuery.getLong("CNT")>0)){
						inETMsg.set(CR0161ETMsg.WKKBT_ORG_CD_ERR, errFlag);
						if("W".equals(errFlag.substring(0,1))){
							rtn = StatusCodes.WARNING;
						} else {
							rtn = StatusCodes.RELATION_ERR;
						}
					}
				}

			}

		} catch(SQLException e) {
			inETMsg.set(CR0161ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
			throw new CAANRuntimeException(e);
		} finally {
			// このメソッドで確保した資源の解放
			try {
				if(rsltQuery != null) {
					rsltQuery.close();
				}
				if(pstmtQuery != null) {
					pstmtQuery.close();
				}
				if(con != null) {
					CAANConnectionMgr.getInstance().close(con);
				}
			} catch(SQLException e) {
				inETMsg.set(CR0161ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
				throw new CAANRuntimeException(e);
			}
		}
		
		// ステータスのセット
		if (rtn > inETMsg.getInt(CR0161ETMsg.STATUS)) {
			inETMsg.set(CR0161ETMsg.STATUS, rtn);
		}

		return rtn;

	}

	/**
	 * ICR0231D001_制約ＮＯ6チェック
	 *
	 * @param inETMsg チェック対象のETMsg(CR0231ETMsg)
	 * @param inContext Agentから渡されたAgentDispatchContext
	 * @param errFlag ERRフラグ
	 * @return int チェック結果
	 */
	private int execICR0231D001_6(CAANMsg inETMsg, AgentDispatchContext inContext, String errFlag){

		// ステータス
		int rtn = 0;

		Connection con = JSYejbConnection.getConnection(ZM0151ETMsg.getTableName());

		PreparedStatement pstmtQuery = null;
		ResultSet rsltQuery = null;
		StringBuffer sqlQuery = new StringBuffer();

		try{

			// チェック条件定数
			// ＳＱＬ引数定義
			String joken1_2 = null;
			if(!inETMsg.isNull(CR0231ETMsg.WKKBT_ORG_CD)){
				joken1_2 = new String(inETMsg.getObject(CR0231ETMsg.WKKBT_ORG_CD).toString());
			}

			String joken2_2 = "0";
			// 条件文定義
			String joken_1 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_CD);
			if(joken1_2 == null){
				joken_1 += " IS NULL ";
			}else{
				joken_1 += " = ? ";
			}

			String joken_2 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.MK_FLG);
			if(joken2_2 == null){
				joken_2 += " IS NULL ";
			}else{
				joken_2 += " = ? ";
			}

			// チェック条件
			if (!inETMsg.isNull(CR0231ETMsg.WKKBT_ORG_CD)) { 

				// ＳＱＬ文の組み立て
				sqlQuery.append("SELECT COUNT(*) CNT FROM ").append(ZM0151ETMsg.getTableName()).append(" WHERE ")
					.append("(" + joken_1 + " AND " + joken_2 + " ) ");

				// ＳＱＬ文の解析
				pstmtQuery = con.prepareStatement(sqlQuery.toString());

				// パラメータの設定
				int para_idx = 1;
				if(joken1_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken1_2);
				}
				if(joken2_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken2_2);
				}

				// ＳＱＬ文の実行
				rsltQuery = pstmtQuery.executeQuery();

				if(rsltQuery.next()){
				// 判定条件
					if(!(rsltQuery.getLong("CNT")>0)){
						inETMsg.set(CR0231ETMsg.WKKBT_ORG_CD_ERR, errFlag);
						if("W".equals(errFlag.substring(0,1))){
							rtn = StatusCodes.WARNING;
						} else {
							rtn = StatusCodes.RELATION_ERR;
						}
					}
				}

			}

		} catch(SQLException e) {
			inETMsg.set(CR0231ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
			throw new CAANRuntimeException(e);
		} finally {
			// このメソッドで確保した資源の解放
			try {
				if(rsltQuery != null) {
					rsltQuery.close();
				}
				if(pstmtQuery != null) {
					pstmtQuery.close();
				}
				if(con != null) {
					CAANConnectionMgr.getInstance().close(con);
				}
			} catch(SQLException e) {
				inETMsg.set(CR0231ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
				throw new CAANRuntimeException(e);
			}
		}
		
		// ステータスのセット
		if (rtn > inETMsg.getInt(CR0231ETMsg.STATUS)) {
			inETMsg.set(CR0231ETMsg.STATUS, rtn);
		}

		return rtn;

	}

	/**
	 * ICR0251D001_制約ＮＯ2チェック
	 *
	 * @param inETMsg チェック対象のETMsg(CR0251ETMsg)
	 * @param inContext Agentから渡されたAgentDispatchContext
	 * @param errFlag ERRフラグ
	 * @return int チェック結果
	 */
	private int execICR0251D001_2(CAANMsg inETMsg, AgentDispatchContext inContext, String errFlag){

		// ステータス
		int rtn = 0;

		Connection con = JSYejbConnection.getConnection(ZM0151ETMsg.getTableName());

		PreparedStatement pstmtQuery = null;
		ResultSet rsltQuery = null;
		StringBuffer sqlQuery = new StringBuffer();

		try{

			// チェック条件定数
			// ＳＱＬ引数定義
			String joken1_2 = null;
			if(!inETMsg.isNull(CR0251ETMsg.WKKBT_ORG_CD)){
				joken1_2 = new String(inETMsg.getObject(CR0251ETMsg.WKKBT_ORG_CD).toString());
			}

			String joken3_2 = "0";
			String joken4_2 = null;
			if(!inETMsg.isNull(CR0251ETMsg.OPERATEDATE)){
				joken4_2 = new String(inETMsg.getObject(CR0251ETMsg.OPERATEDATE).toString());
			}

			String joken5_2 = null;
			if(!inETMsg.isNull(CR0251ETMsg.OPERATEDATE)){
				joken5_2 = new String(inETMsg.getObject(CR0251ETMsg.OPERATEDATE).toString());
			}

			// 条件文定義
			String joken_1 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_CD);
			if(joken1_2 == null){
				joken_1 += " IS NULL ";
			}else{
				joken_1 += " = ? ";
			}

			String joken_3 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.MK_FLG);
			if(joken3_2 == null){
				joken_3 += " IS NULL ";
			}else{
				joken_3 += " = ? ";
			}

			String joken_4 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TSTAYMD);
			if(joken4_2 == null){
				joken_4 += " IS NULL ";
			}else{
				joken_4 += " <= ? ";
			}

			String joken_5 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TENDYMD);
			if(joken5_2 == null){
				joken_5 += " IS NULL ";
			}else{
				joken_5 += " >= ? ";
			}

			// チェック条件
			if (!inETMsg.isNull(CR0251ETMsg.WKKBT_ORG_CD)) { 

				// ＳＱＬ文の組み立て
				sqlQuery.append("SELECT COUNT(*) CNT FROM ").append(ZM0151ETMsg.getTableName()).append(" WHERE ")
					.append("(" + "(" + "(" + joken_1 + " AND " + joken_3 + " ) " + " AND " + joken_4 + " ) " + " AND " + joken_5 + " ) ");

				// ＳＱＬ文の解析
				pstmtQuery = con.prepareStatement(sqlQuery.toString());

				// パラメータの設定
				int para_idx = 1;
				if(joken1_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken1_2);
				}
				if(joken3_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken3_2);
				}
				if(joken4_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken4_2);
				}
				if(joken5_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken5_2);
				}

				// ＳＱＬ文の実行
				rsltQuery = pstmtQuery.executeQuery();

				if(rsltQuery.next()){
				// 判定条件
					if(!(rsltQuery.getLong("CNT")>0)){
						inETMsg.set(CR0251ETMsg.WKKBT_ORG_CD_ERR, errFlag);
						if("W".equals(errFlag.substring(0,1))){
							rtn = StatusCodes.WARNING;
						} else {
							rtn = StatusCodes.RELATION_ERR;
						}
					}
				}

			}

		} catch(SQLException e) {
			inETMsg.set(CR0251ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
			throw new CAANRuntimeException(e);
		} finally {
			// このメソッドで確保した資源の解放
			try {
				if(rsltQuery != null) {
					rsltQuery.close();
				}
				if(pstmtQuery != null) {
					pstmtQuery.close();
				}
				if(con != null) {
					CAANConnectionMgr.getInstance().close(con);
				}
			} catch(SQLException e) {
				inETMsg.set(CR0251ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
				throw new CAANRuntimeException(e);
			}
		}
		
		// ステータスのセット
		if (rtn > inETMsg.getInt(CR0251ETMsg.STATUS)) {
			inETMsg.set(CR0251ETMsg.STATUS, rtn);
		}

		return rtn;

	}

	/**
	 * ICR0301D001_制約ＮＯ2チェック
	 *
	 * @param inETMsg チェック対象のETMsg(CR0301ETMsg)
	 * @param inContext Agentから渡されたAgentDispatchContext
	 * @param errFlag ERRフラグ
	 * @return int チェック結果
	 */
	private int execICR0301D001_2(CAANMsg inETMsg, AgentDispatchContext inContext, String errFlag){

		// ステータス
		int rtn = 0;

		Connection con = JSYejbConnection.getConnection(ZM0151ETMsg.getTableName());

		PreparedStatement pstmtQuery = null;
		ResultSet rsltQuery = null;
		StringBuffer sqlQuery = new StringBuffer();

		try{

			// チェック条件定数
			// ＳＱＬ引数定義
			String joken1_2 = null;
			if(!inETMsg.isNull(CR0301ETMsg.WKKBT_ORG_CD)){
				joken1_2 = new String(inETMsg.getObject(CR0301ETMsg.WKKBT_ORG_CD).toString());
			}

			String joken2_2 = "0";
			String joken3_2 = null;
			if(!inETMsg.isNull(CR0301ETMsg.OPERATEDATE)){
				joken3_2 = new String(inETMsg.getObject(CR0301ETMsg.OPERATEDATE).toString());
			}

			String joken4_2 = null;
			if(!inETMsg.isNull(CR0301ETMsg.OPERATEDATE)){
				joken4_2 = new String(inETMsg.getObject(CR0301ETMsg.OPERATEDATE).toString());
			}

			// 条件文定義
			String joken_1 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_CD);
			if(joken1_2 == null){
				joken_1 += " IS NULL ";
			}else{
				joken_1 += " = ? ";
			}

			String joken_2 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.MK_FLG);
			if(joken2_2 == null){
				joken_2 += " IS NULL ";
			}else{
				joken_2 += " = ? ";
			}

			String joken_3 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TSTAYMD);
			if(joken3_2 == null){
				joken_3 += " IS NULL ";
			}else{
				joken_3 += " <= ? ";
			}

			String joken_4 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TENDYMD);
			if(joken4_2 == null){
				joken_4 += " IS NULL ";
			}else{
				joken_4 += " >= ? ";
			}

			// チェック条件
			if (!inETMsg.isNull(CR0301ETMsg.WKKBT_ORG_CD)) { 

				// ＳＱＬ文の組み立て
				sqlQuery.append("SELECT COUNT(*) CNT FROM ").append(ZM0151ETMsg.getTableName()).append(" WHERE ")
					.append("(" + "(" + "(" + joken_1 + " AND " + joken_2 + " ) " + " AND " + joken_3 + " ) " + " AND " + joken_4 + " ) ");

				// ＳＱＬ文の解析
				pstmtQuery = con.prepareStatement(sqlQuery.toString());

				// パラメータの設定
				int para_idx = 1;
				if(joken1_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken1_2);
				}
				if(joken2_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken2_2);
				}
				if(joken3_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken3_2);
				}
				if(joken4_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken4_2);
				}

				// ＳＱＬ文の実行
				rsltQuery = pstmtQuery.executeQuery();

				if(rsltQuery.next()){
				// 判定条件
					if(!(rsltQuery.getLong("CNT")>0)){
						inETMsg.set(CR0301ETMsg.WKKBT_ORG_CD_ERR, errFlag);
						if("W".equals(errFlag.substring(0,1))){
							rtn = StatusCodes.WARNING;
						} else {
							rtn = StatusCodes.RELATION_ERR;
						}
					}
				}

			}

		} catch(SQLException e) {
			inETMsg.set(CR0301ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
			throw new CAANRuntimeException(e);
		} finally {
			// このメソッドで確保した資源の解放
			try {
				if(rsltQuery != null) {
					rsltQuery.close();
				}
				if(pstmtQuery != null) {
					pstmtQuery.close();
				}
				if(con != null) {
					CAANConnectionMgr.getInstance().close(con);
				}
			} catch(SQLException e) {
				inETMsg.set(CR0301ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
				throw new CAANRuntimeException(e);
			}
		}
		
		// ステータスのセット
		if (rtn > inETMsg.getInt(CR0301ETMsg.STATUS)) {
			inETMsg.set(CR0301ETMsg.STATUS, rtn);
		}

		return rtn;

	}

	/**
	 * ICR0411D001_制約ＮＯ8チェック
	 *
	 * @param inETMsg チェック対象のETMsg(CR0411ETMsg)
	 * @param inContext Agentから渡されたAgentDispatchContext
	 * @param errFlag ERRフラグ
	 * @return int チェック結果
	 */
	private int execICR0411D001_8(CAANMsg inETMsg, AgentDispatchContext inContext, String errFlag){

		// ステータス
		int rtn = 0;

		Connection con = JSYejbConnection.getConnection(ZM0151ETMsg.getTableName());

		PreparedStatement pstmtQuery = null;
		ResultSet rsltQuery = null;
		StringBuffer sqlQuery = new StringBuffer();

		try{

			// チェック条件定数
			// ＳＱＬ引数定義
			String joken1_2 = null;
			if(!inETMsg.isNull(CR0411ETMsg.WKKBT_ORG_CD)){
				joken1_2 = new String(inETMsg.getObject(CR0411ETMsg.WKKBT_ORG_CD).toString());
			}

			String joken2_2 = null;
			if(!inETMsg.isNull(CR0411ETMsg.OPERATEDATE)){
				joken2_2 = new String(inETMsg.getObject(CR0411ETMsg.OPERATEDATE).toString());
			}

			String joken3_2 = null;
			if(!inETMsg.isNull(CR0411ETMsg.OPERATEDATE)){
				joken3_2 = new String(inETMsg.getObject(CR0411ETMsg.OPERATEDATE).toString());
			}

			String joken4_2 = "0";
			// 条件文定義
			String joken_1 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_CD);
			if(joken1_2 == null){
				joken_1 += " IS NULL ";
			}else{
				joken_1 += " = ? ";
			}

			String joken_2 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TSTAYMD);
			if(joken2_2 == null){
				joken_2 += " IS NULL ";
			}else{
				joken_2 += " <= ? ";
			}

			String joken_3 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TENDYMD);
			if(joken3_2 == null){
				joken_3 += " IS NULL ";
			}else{
				joken_3 += " >= ? ";
			}

			String joken_4 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.MK_FLG);
			if(joken4_2 == null){
				joken_4 += " IS NULL ";
			}else{
				joken_4 += " = ? ";
			}

			// チェック条件
			if (!inETMsg.isNull(CR0411ETMsg.WKKBT_ORG_CD)) { 

				// ＳＱＬ文の組み立て
				sqlQuery.append("SELECT COUNT(*) CNT FROM ").append(ZM0151ETMsg.getTableName()).append(" WHERE ")
					.append("(" + "(" + "(" + joken_1 + " AND " + joken_2 + " ) " + " AND " + joken_3 + " ) " + " AND " + joken_4 + " ) ");

				// ＳＱＬ文の解析
				pstmtQuery = con.prepareStatement(sqlQuery.toString());

				// パラメータの設定
				int para_idx = 1;
				if(joken1_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken1_2);
				}
				if(joken2_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken2_2);
				}
				if(joken3_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken3_2);
				}
				if(joken4_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken4_2);
				}

				// ＳＱＬ文の実行
				rsltQuery = pstmtQuery.executeQuery();

				if(rsltQuery.next()){
				// 判定条件
					if(!(rsltQuery.getLong("CNT")>0)){
						inETMsg.set(CR0411ETMsg.WKKBT_ORG_CD_ERR, errFlag);
						if("W".equals(errFlag.substring(0,1))){
							rtn = StatusCodes.WARNING;
						} else {
							rtn = StatusCodes.RELATION_ERR;
						}
					}
				}

			}

		} catch(SQLException e) {
			inETMsg.set(CR0411ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
			throw new CAANRuntimeException(e);
		} finally {
			// このメソッドで確保した資源の解放
			try {
				if(rsltQuery != null) {
					rsltQuery.close();
				}
				if(pstmtQuery != null) {
					pstmtQuery.close();
				}
				if(con != null) {
					CAANConnectionMgr.getInstance().close(con);
				}
			} catch(SQLException e) {
				inETMsg.set(CR0411ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
				throw new CAANRuntimeException(e);
			}
		}
		
		// ステータスのセット
		if (rtn > inETMsg.getInt(CR0411ETMsg.STATUS)) {
			inETMsg.set(CR0411ETMsg.STATUS, rtn);
		}

		return rtn;

	}

	/**
	 * IZM0041C001_制約ＮＯ7チェック
	 *
	 * @param inETMsg チェック対象のETMsg(ZM0041ETMsg)
	 * @param inContext Agentから渡されたAgentDispatchContext
	 * @param errFlag ERRフラグ
	 * @return int チェック結果
	 */
	private int execIZM0041C001_7(CAANMsg inETMsg, AgentDispatchContext inContext, String errFlag){

		// ステータス
		int rtn = 0;

		Connection con = JSYejbConnection.getConnection(ZM0151ETMsg.getTableName());

		PreparedStatement pstmtQuery = null;
		ResultSet rsltQuery = null;
		StringBuffer sqlQuery = new StringBuffer();

		try{

			// チェック条件定数
			String joken2_1 = new String();
			if(!inETMsg.isNull(ZM0041ETMsg.AUTHORITY_APLY_ORG_SBT_CD)){
				joken2_1 = inETMsg.getObject(ZM0041ETMsg.AUTHORITY_APLY_ORG_SBT_CD).toString();
			}

			String joken2_2 = "01";

			// ＳＱＬ引数定義
			String joken1_2 = null;
			if(!inETMsg.isNull(ZM0041ETMsg.WKKBT_ORG_CD)){
				joken1_2 = new String(inETMsg.getObject(ZM0041ETMsg.WKKBT_ORG_CD).toString());
			}

			String joken3_2 = "0";
			// 条件文定義
			String joken_1 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_CD);
			if(joken1_2 == null){
				joken_1 += " IS NULL ";
			}else{
				joken_1 += " = ? ";
			}

			String joken_3 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.MK_FLG);
			if(joken3_2 == null){
				joken_3 += " IS NULL ";
			}else{
				joken_3 += " = ? ";
			}

			// チェック条件
			if (joken2_1.compareTo(joken2_2) != 0) { 

				// ＳＱＬ文の組み立て
				sqlQuery.append("SELECT COUNT(*) CNT FROM ").append(ZM0151ETMsg.getTableName()).append(" WHERE ")
					.append("(" + joken_1 + " AND " + joken_3 + " ) ");

				// ＳＱＬ文の解析
				pstmtQuery = con.prepareStatement(sqlQuery.toString());

				// パラメータの設定
				int para_idx = 1;
				if(joken1_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken1_2);
				}
				if(joken3_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken3_2);
				}

				// ＳＱＬ文の実行
				rsltQuery = pstmtQuery.executeQuery();

				if(rsltQuery.next()){
				// 判定条件
					if(!(rsltQuery.getLong("CNT")>0)){
						inETMsg.set(ZM0041ETMsg.WKKBT_ORG_CD_ERR, errFlag);
						if("W".equals(errFlag.substring(0,1))){
							rtn = StatusCodes.WARNING;
						} else {
							rtn = StatusCodes.RELATION_ERR;
						}
					}
				}

			}

		} catch(SQLException e) {
			inETMsg.set(ZM0041ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
			throw new CAANRuntimeException(e);
		} finally {
			// このメソッドで確保した資源の解放
			try {
				if(rsltQuery != null) {
					rsltQuery.close();
				}
				if(pstmtQuery != null) {
					pstmtQuery.close();
				}
				if(con != null) {
					CAANConnectionMgr.getInstance().close(con);
				}
			} catch(SQLException e) {
				inETMsg.set(ZM0041ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
				throw new CAANRuntimeException(e);
			}
		}
		
		// ステータスのセット
		if (rtn > inETMsg.getInt(ZM0041ETMsg.STATUS)) {
			inETMsg.set(ZM0041ETMsg.STATUS, rtn);
		}

		return rtn;

	}

	/**
	 * IZM0041C001_制約ＮＯ8チェック
	 *
	 * @param inETMsg チェック対象のETMsg(ZM0041ETMsg)
	 * @param inContext Agentから渡されたAgentDispatchContext
	 * @param errFlag ERRフラグ
	 * @return int チェック結果
	 */
	private int execIZM0041C001_8(CAANMsg inETMsg, AgentDispatchContext inContext, String errFlag){

		// ステータス
		int rtn = 0;

		Connection con = JSYejbConnection.getConnection(ZM0151ETMsg.getTableName());

		PreparedStatement pstmtQuery = null;
		ResultSet rsltQuery = null;
		StringBuffer sqlQuery = new StringBuffer();

		try{

			// チェック条件定数
			String joken2_1 = new String();
			if(!inETMsg.isNull(ZM0041ETMsg.AUTHORITY_APLY_ORG_SBT_CD)){
				joken2_1 = inETMsg.getObject(ZM0041ETMsg.AUTHORITY_APLY_ORG_SBT_CD).toString();
			}

			String joken2_2 = "01";

			// ＳＱＬ引数定義
			String joken1_2 = null;
			if(!inETMsg.isNull(ZM0041ETMsg.WKKBT_ORG_CD)){
				joken1_2 = new String(inETMsg.getObject(ZM0041ETMsg.WKKBT_ORG_CD).toString());
			}

			String joken3_2 = null;
			if(!inETMsg.isNull(ZM0041ETMsg.AUTHORITY_APLY_ORG_SBT_CD)){
				joken3_2 = new String(inETMsg.getObject(ZM0041ETMsg.AUTHORITY_APLY_ORG_SBT_CD).toString());
			}

			String joken4_2 = "0";
			// 条件文定義
			String joken_1 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_CD);
			if(joken1_2 == null){
				joken_1 += " IS NULL ";
			}else{
				joken_1 += " = ? ";
			}

			String joken_3 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.AUTHORITY_APLY_ORG_SBT_CD);
			if(joken3_2 == null){
				joken_3 += " IS NULL ";
			}else{
				joken_3 += " = ? ";
			}

			String joken_4 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.MK_FLG);
			if(joken4_2 == null){
				joken_4 += " IS NULL ";
			}else{
				joken_4 += " = ? ";
			}

			// チェック条件
			if (joken2_1.compareTo(joken2_2) != 0) { 

				// ＳＱＬ文の組み立て
				sqlQuery.append("SELECT COUNT(*) CNT FROM ").append(ZM0151ETMsg.getTableName()).append(" WHERE ")
					.append("(" + "(" + joken_1 + " AND " + joken_3 + " ) " + " AND " + joken_4 + " ) ");

				// ＳＱＬ文の解析
				pstmtQuery = con.prepareStatement(sqlQuery.toString());

				// パラメータの設定
				int para_idx = 1;
				if(joken1_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken1_2);
				}
				if(joken3_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken3_2);
				}
				if(joken4_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken4_2);
				}

				// ＳＱＬ文の実行
				rsltQuery = pstmtQuery.executeQuery();

				if(rsltQuery.next()){
				// 判定条件
					if(!(rsltQuery.getLong("CNT")>0)){
						inETMsg.set(ZM0041ETMsg.WKKBT_ORG_CD_ERR, errFlag);
						if("W".equals(errFlag.substring(0,1))){
							rtn = StatusCodes.WARNING;
						} else {
							rtn = StatusCodes.RELATION_ERR;
						}
					}
				}

			}

		} catch(SQLException e) {
			inETMsg.set(ZM0041ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
			throw new CAANRuntimeException(e);
		} finally {
			// このメソッドで確保した資源の解放
			try {
				if(rsltQuery != null) {
					rsltQuery.close();
				}
				if(pstmtQuery != null) {
					pstmtQuery.close();
				}
				if(con != null) {
					CAANConnectionMgr.getInstance().close(con);
				}
			} catch(SQLException e) {
				inETMsg.set(ZM0041ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
				throw new CAANRuntimeException(e);
			}
		}
		
		// ステータスのセット
		if (rtn > inETMsg.getInt(ZM0041ETMsg.STATUS)) {
			inETMsg.set(ZM0041ETMsg.STATUS, rtn);
		}

		return rtn;

	}

	/**
	 * IZM0041C001_制約ＮＯ9チェック
	 *
	 * @param inETMsg チェック対象のETMsg(ZM0041ETMsg)
	 * @param inContext Agentから渡されたAgentDispatchContext
	 * @param errFlag ERRフラグ
	 * @return int チェック結果
	 */
	private int execIZM0041C001_9(CAANMsg inETMsg, AgentDispatchContext inContext, String errFlag){

		// ステータス
		int rtn = 0;

		Connection con = JSYejbConnection.getConnection(ZM0151ETMsg.getTableName());

		PreparedStatement pstmtQuery = null;
		ResultSet rsltQuery = null;
		StringBuffer sqlQuery = new StringBuffer();

		try{

			// チェック条件定数
			String joken2_1 = new String();
			if(!inETMsg.isNull(ZM0041ETMsg.AUTHORITY_APLY_ORG_SBT_CD)){
				joken2_1 = inETMsg.getObject(ZM0041ETMsg.AUTHORITY_APLY_ORG_SBT_CD).toString();
			}

			String joken2_2 = "01";

			// ＳＱＬ引数定義
			String joken1_2 = null;
			if(!inETMsg.isNull(ZM0041ETMsg.WKKBT_ORG_CD)){
				joken1_2 = new String(inETMsg.getObject(ZM0041ETMsg.WKKBT_ORG_CD).toString());
			}

			String joken3_2 = null;
			if(!inETMsg.isNull(ZM0041ETMsg.OPERATEDATE)){
				joken3_2 = new String(inETMsg.getObject(ZM0041ETMsg.OPERATEDATE).toString());
			}

			String joken4_2 = "0";
			// 条件文定義
			String joken_1 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_CD);
			if(joken1_2 == null){
				joken_1 += " IS NULL ";
			}else{
				joken_1 += " = ? ";
			}

			String joken_3 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TENDYMD);
			if(joken3_2 == null){
				joken_3 += " IS NULL ";
			}else{
				joken_3 += " < ? ";
			}

			String joken_4 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.MK_FLG);
			if(joken4_2 == null){
				joken_4 += " IS NULL ";
			}else{
				joken_4 += " = ? ";
			}

			// チェック条件
			if (joken2_1.compareTo(joken2_2) != 0) { 

				// ＳＱＬ文の組み立て
				sqlQuery.append("SELECT COUNT(*) CNT FROM ").append(ZM0151ETMsg.getTableName()).append(" WHERE ")
					.append("(" + "(" + joken_1 + " AND " + joken_3 + " ) " + " AND " + joken_4 + " ) ");

				// ＳＱＬ文の解析
				pstmtQuery = con.prepareStatement(sqlQuery.toString());

				// パラメータの設定
				int para_idx = 1;
				if(joken1_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken1_2);
				}
				if(joken3_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken3_2);
				}
				if(joken4_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken4_2);
				}

				// ＳＱＬ文の実行
				rsltQuery = pstmtQuery.executeQuery();

				if(rsltQuery.next()){
				// 判定条件
					if(rsltQuery.getLong("CNT")>0){
						inETMsg.set(ZM0041ETMsg.WKKBT_ORG_CD_ERR, errFlag);
						if("W".equals(errFlag.substring(0,1))){
							rtn = StatusCodes.WARNING;
						} else {
							rtn = StatusCodes.RELATION_ERR;
						}
					}
				}

			}

		} catch(SQLException e) {
			inETMsg.set(ZM0041ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
			throw new CAANRuntimeException(e);
		} finally {
			// このメソッドで確保した資源の解放
			try {
				if(rsltQuery != null) {
					rsltQuery.close();
				}
				if(pstmtQuery != null) {
					pstmtQuery.close();
				}
				if(con != null) {
					CAANConnectionMgr.getInstance().close(con);
				}
			} catch(SQLException e) {
				inETMsg.set(ZM0041ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
				throw new CAANRuntimeException(e);
			}
		}
		
		// ステータスのセット
		if (rtn > inETMsg.getInt(ZM0041ETMsg.STATUS)) {
			inETMsg.set(ZM0041ETMsg.STATUS, rtn);
		}

		return rtn;

	}

	/**
	 * IZM0041D001_制約ＮＯ7チェック
	 *
	 * @param inETMsg チェック対象のETMsg(ZM0041ETMsg)
	 * @param inContext Agentから渡されたAgentDispatchContext
	 * @param errFlag ERRフラグ
	 * @return int チェック結果
	 */
	private int execIZM0041D001_7(CAANMsg inETMsg, AgentDispatchContext inContext, String errFlag){

		// ステータス
		int rtn = 0;

		Connection con = JSYejbConnection.getConnection(ZM0151ETMsg.getTableName());

		PreparedStatement pstmtQuery = null;
		ResultSet rsltQuery = null;
		StringBuffer sqlQuery = new StringBuffer();

		try{

			// チェック条件定数
			String joken2_1 = new String();
			if(!inETMsg.isNull(ZM0041ETMsg.AUTHORITY_APLY_ORG_SBT_CD)){
				joken2_1 = inETMsg.getObject(ZM0041ETMsg.AUTHORITY_APLY_ORG_SBT_CD).toString();
			}

			String joken2_2 = "01";

			// ＳＱＬ引数定義
			String joken1_2 = null;
			if(!inETMsg.isNull(ZM0041ETMsg.WKKBT_ORG_CD)){
				joken1_2 = new String(inETMsg.getObject(ZM0041ETMsg.WKKBT_ORG_CD).toString());
			}

			String joken3_2 = "0";
			// 条件文定義
			String joken_1 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_CD);
			if(joken1_2 == null){
				joken_1 += " IS NULL ";
			}else{
				joken_1 += " = ? ";
			}

			String joken_3 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.MK_FLG);
			if(joken3_2 == null){
				joken_3 += " IS NULL ";
			}else{
				joken_3 += " = ? ";
			}

			// チェック条件
			if (joken2_1.compareTo(joken2_2) != 0) { 

				// ＳＱＬ文の組み立て
				sqlQuery.append("SELECT COUNT(*) CNT FROM ").append(ZM0151ETMsg.getTableName()).append(" WHERE ")
					.append("(" + joken_1 + " AND " + joken_3 + " ) ");

				// ＳＱＬ文の解析
				pstmtQuery = con.prepareStatement(sqlQuery.toString());

				// パラメータの設定
				int para_idx = 1;
				if(joken1_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken1_2);
				}
				if(joken3_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken3_2);
				}

				// ＳＱＬ文の実行
				rsltQuery = pstmtQuery.executeQuery();

				if(rsltQuery.next()){
				// 判定条件
					if(!(rsltQuery.getLong("CNT")>0)){
						inETMsg.set(ZM0041ETMsg.WKKBT_ORG_CD_ERR, errFlag);
						if("W".equals(errFlag.substring(0,1))){
							rtn = StatusCodes.WARNING;
						} else {
							rtn = StatusCodes.RELATION_ERR;
						}
					}
				}

			}

		} catch(SQLException e) {
			inETMsg.set(ZM0041ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
			throw new CAANRuntimeException(e);
		} finally {
			// このメソッドで確保した資源の解放
			try {
				if(rsltQuery != null) {
					rsltQuery.close();
				}
				if(pstmtQuery != null) {
					pstmtQuery.close();
				}
				if(con != null) {
					CAANConnectionMgr.getInstance().close(con);
				}
			} catch(SQLException e) {
				inETMsg.set(ZM0041ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
				throw new CAANRuntimeException(e);
			}
		}
		
		// ステータスのセット
		if (rtn > inETMsg.getInt(ZM0041ETMsg.STATUS)) {
			inETMsg.set(ZM0041ETMsg.STATUS, rtn);
		}

		return rtn;

	}

	/**
	 * IZM0041D001_制約ＮＯ8チェック
	 *
	 * @param inETMsg チェック対象のETMsg(ZM0041ETMsg)
	 * @param inContext Agentから渡されたAgentDispatchContext
	 * @param errFlag ERRフラグ
	 * @return int チェック結果
	 */
	private int execIZM0041D001_8(CAANMsg inETMsg, AgentDispatchContext inContext, String errFlag){

		// ステータス
		int rtn = 0;

		Connection con = JSYejbConnection.getConnection(ZM0151ETMsg.getTableName());

		PreparedStatement pstmtQuery = null;
		ResultSet rsltQuery = null;
		StringBuffer sqlQuery = new StringBuffer();

		try{

			// チェック条件定数
			String joken2_1 = new String();
			if(!inETMsg.isNull(ZM0041ETMsg.AUTHORITY_APLY_ORG_SBT_CD)){
				joken2_1 = inETMsg.getObject(ZM0041ETMsg.AUTHORITY_APLY_ORG_SBT_CD).toString();
			}

			String joken2_2 = "01";

			// ＳＱＬ引数定義
			String joken1_2 = null;
			if(!inETMsg.isNull(ZM0041ETMsg.WKKBT_ORG_CD)){
				joken1_2 = new String(inETMsg.getObject(ZM0041ETMsg.WKKBT_ORG_CD).toString());
			}

			String joken3_2 = null;
			if(!inETMsg.isNull(ZM0041ETMsg.AUTHORITY_APLY_ORG_SBT_CD)){
				joken3_2 = new String(inETMsg.getObject(ZM0041ETMsg.AUTHORITY_APLY_ORG_SBT_CD).toString());
			}

			String joken4_2 = "0";
			// 条件文定義
			String joken_1 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_CD);
			if(joken1_2 == null){
				joken_1 += " IS NULL ";
			}else{
				joken_1 += " = ? ";
			}

			String joken_3 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.AUTHORITY_APLY_ORG_SBT_CD);
			if(joken3_2 == null){
				joken_3 += " IS NULL ";
			}else{
				joken_3 += " = ? ";
			}

			String joken_4 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.MK_FLG);
			if(joken4_2 == null){
				joken_4 += " IS NULL ";
			}else{
				joken_4 += " = ? ";
			}

			// チェック条件
			if (joken2_1.compareTo(joken2_2) != 0) { 

				// ＳＱＬ文の組み立て
				sqlQuery.append("SELECT COUNT(*) CNT FROM ").append(ZM0151ETMsg.getTableName()).append(" WHERE ")
					.append("(" + "(" + joken_1 + " AND " + joken_3 + " ) " + " AND " + joken_4 + " ) ");

				// ＳＱＬ文の解析
				pstmtQuery = con.prepareStatement(sqlQuery.toString());

				// パラメータの設定
				int para_idx = 1;
				if(joken1_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken1_2);
				}
				if(joken3_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken3_2);
				}
				if(joken4_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken4_2);
				}

				// ＳＱＬ文の実行
				rsltQuery = pstmtQuery.executeQuery();

				if(rsltQuery.next()){
				// 判定条件
					if(!(rsltQuery.getLong("CNT")>0)){
						inETMsg.set(ZM0041ETMsg.WKKBT_ORG_CD_ERR, errFlag);
						if("W".equals(errFlag.substring(0,1))){
							rtn = StatusCodes.WARNING;
						} else {
							rtn = StatusCodes.RELATION_ERR;
						}
					}
				}

			}

		} catch(SQLException e) {
			inETMsg.set(ZM0041ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
			throw new CAANRuntimeException(e);
		} finally {
			// このメソッドで確保した資源の解放
			try {
				if(rsltQuery != null) {
					rsltQuery.close();
				}
				if(pstmtQuery != null) {
					pstmtQuery.close();
				}
				if(con != null) {
					CAANConnectionMgr.getInstance().close(con);
				}
			} catch(SQLException e) {
				inETMsg.set(ZM0041ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
				throw new CAANRuntimeException(e);
			}
		}
		
		// ステータスのセット
		if (rtn > inETMsg.getInt(ZM0041ETMsg.STATUS)) {
			inETMsg.set(ZM0041ETMsg.STATUS, rtn);
		}

		return rtn;

	}

	/**
	 * IZM0041D001_制約ＮＯ9チェック
	 *
	 * @param inETMsg チェック対象のETMsg(ZM0041ETMsg)
	 * @param inContext Agentから渡されたAgentDispatchContext
	 * @param errFlag ERRフラグ
	 * @return int チェック結果
	 */
	private int execIZM0041D001_9(CAANMsg inETMsg, AgentDispatchContext inContext, String errFlag){

		// ステータス
		int rtn = 0;

		Connection con = JSYejbConnection.getConnection(ZM0151ETMsg.getTableName());

		PreparedStatement pstmtQuery = null;
		ResultSet rsltQuery = null;
		StringBuffer sqlQuery = new StringBuffer();

		try{

			// チェック条件定数
			String joken2_1 = new String();
			if(!inETMsg.isNull(ZM0041ETMsg.AUTHORITY_APLY_ORG_SBT_CD)){
				joken2_1 = inETMsg.getObject(ZM0041ETMsg.AUTHORITY_APLY_ORG_SBT_CD).toString();
			}

			String joken2_2 = "01";

			// ＳＱＬ引数定義
			String joken1_2 = null;
			if(!inETMsg.isNull(ZM0041ETMsg.WKKBT_ORG_CD)){
				joken1_2 = new String(inETMsg.getObject(ZM0041ETMsg.WKKBT_ORG_CD).toString());
			}

			String joken3_2 = null;
			if(!inETMsg.isNull(ZM0041ETMsg.OPERATEDATE)){
				joken3_2 = new String(inETMsg.getObject(ZM0041ETMsg.OPERATEDATE).toString());
			}

			String joken4_2 = "0";
			// 条件文定義
			String joken_1 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_CD);
			if(joken1_2 == null){
				joken_1 += " IS NULL ";
			}else{
				joken_1 += " = ? ";
			}

			String joken_3 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.WKKBT_ORG_TENDYMD);
			if(joken3_2 == null){
				joken_3 += " IS NULL ";
			}else{
				joken_3 += " < ? ";
			}

			String joken_4 = ZM0151ETMsg.getDBColumnName(ZM0151ETMsg.MK_FLG);
			if(joken4_2 == null){
				joken_4 += " IS NULL ";
			}else{
				joken_4 += " = ? ";
			}

			// チェック条件
			if (joken2_1.compareTo(joken2_2) != 0) { 

				// ＳＱＬ文の組み立て
				sqlQuery.append("SELECT COUNT(*) CNT FROM ").append(ZM0151ETMsg.getTableName()).append(" WHERE ")
					.append("(" + "(" + joken_1 + " AND " + joken_3 + " ) " + " AND " + joken_4 + " ) ");

				// ＳＱＬ文の解析
				pstmtQuery = con.prepareStatement(sqlQuery.toString());

				// パラメータの設定
				int para_idx = 1;
				if(joken1_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken1_2);
				}
				if(joken3_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken3_2);
				}
				if(joken4_2 != null){
					CAANJDBCUtil.setParam(pstmtQuery, para_idx++ , joken4_2);
				}

				// ＳＱＬ文の実行
				rsltQuery = pstmtQuery.executeQuery();

				if(rsltQuery.next()){
				// 判定条件
					if(rsltQuery.getLong("CNT")>0){
						inETMsg.set(ZM0041ETMsg.WKKBT_ORG_CD_ERR, errFlag);
						if("W".equals(errFlag.substring(0,1))){
							rtn = StatusCodes.WARNING;
						} else {
							rtn = StatusCodes.RELATION_ERR;
						}
					}
				}

			}

		} catch(SQLException e) {
			inETMsg.set(ZM0041ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
			throw new CAANRuntimeException(e);
		} finally {
			// このメソッドで確保した資源の解放
			try {
				if(rsltQuery != null) {
					rsltQuery.close();
				}
				if(pstmtQuery != null) {
					pstmtQuery.close();
				}
				if(con != null) {
					CAANConnectionMgr.getInstance().close(con);
				}
			} catch(SQLException e) {
				inETMsg.set(ZM0041ETMsg.STATUS, StatusCodes.FIND_DB_ERR);
				throw new CAANRuntimeException(e);
			}
		}
		
		// ステータスのセット
		if (rtn > inETMsg.getInt(ZM0041ETMsg.STATUS)) {
			inETMsg.set(ZM0041ETMsg.STATUS, rtn);
		}

		return rtn;

	}

}

