#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：請求収納
#
# シェル名      ：フロアリミット超過フラグ更新対象抽出
#
# 機能          ：当月の請求情報のフロアリミット超過フラグを抽出する。
#
# コマンド形式  ：EO6010140J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v4.00           2013/03/18  FJ）広野     性能改善: アンロードの参照先スクリプト変更にともなう修正
# v4.00.01        2013/04/08  FJ) 狭間    【ST4-2013-0000286】性能改善の為、アンロード並列化及び処理見直しと水平展開
##############################################################

##############################################################
# 環境変数定義
##############################################################

#
#---ツール格納場所
#
G_TOOLSH=.

#
#---環境変数定義Shell呼び出し
#
. EOK010110J0.sh

#
#---ＪＯＢ名
#
JOBNAME=`basename $0 | sed -e "s/\.sh//g"`

#
#---サービス（業務プロセス）
#
SVC=$JOBNAME

#
#---OPD
#
OPD=$1

#
#---業務で必要な変数定義
#
[ $# -eq 2 ] &&TAJUKIDO="_$2" ;
#---ワークファイル削除モード
WK_RM=true ;

#---マッチング処理でLeftjoinがNULL時に"を付けなくする（マッチング使用時は必須）
export ZTLQUOTES=''

##############################################################
# 業務処理
##############################################################
sh ${G_TOOLSH}/EOK010210J0.sh CS00025I $JOBNAME

#
#---パラメタ定義
#

P1="OPD=,"
P2="SVCCTL=,"
P3="JOB=EO6010140J0,"
P4="IND1=,"
P5="INF1=,"
P6="IND2=,"
P7="INF2=,"
P8="OTD1=,"
P9="OTF1=,"
P10="OTD2=,"
P11="OTF2=,"
P12="TABLENAME=,"
P13="SQLKEY=,"
P14="SQLPARAM=,"
P15="ERRFILE=,"
P16="RECOVERY=,"
P17="BREAKPTN=,"
P18="FREE="
PARA="$P1$P2$P3$P4$P5$P6$P7$P8$P9$P10$P11$P12$P13$P14$P15$P16$P17$P18"

sh ${G_TOOLSH}/EOK010210J0.sh CS00027I $JOBNAME

#
#--- ファイル定義
#
INFILE=${MID_DIR_CH}/CHIFM143001.csv
INFILE_WRK=${MID_DIR_CH}/CHIFM143001_WRK_${JOBNAME}.csv
OUTFILE=${MID_DIR_CH}/CHIFM167001.csv
INFILE_2=${MID_DIR_CH}/CHIFM179001.csv
OUTFILE_WRK=${MID_DIR_CH}/${JOBNAME}_CHIFM167001_OUT_WK_2$TAJUKIDO.csv
CH_T_SEIKKY_DEF=${G_TOOLSH}/util/def/CH_CM_0023.def
DEF_FILE_WK1=${MID_DIR_CH}/${JOBNAME}_CH_CM_0023_MATCHING_WK_1$TAJUKIDO.def

#
#--- 各ファイルの存在チェックを行う
#
if [ ! -r $CH_T_SEIKKY_DEF ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " File is nonexist($CH_T_SEIKKY_DEF) "
    echo $JOBNAME " File is nonexist($CH_T_SEIKKY_DEF) "
    exit ${G_RTN_ERROR}
fi

#
#--- 入力ファイルから、余分な項目を削除する。
#

bsort -s -z3000 -Tflt -t, -0.10asca -e0.10,44.1 -o ${INFILE_WRK} ${INFILE}

rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " SORT Error($SVC sort:rc=$rc) "
    echo $JOBNAME " SORT Error($SVC sort:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

#
#- 当月請求情報と請求内訳情報をマッチングする。
#- マッチング用のdefファイルのファイル名変数を実ファイル名に置き換える。
#
cp ${CH_T_SEIKKY_DEF} ${DEF_FILE_WK1}

sed -i -e "s%:CH_T_SEIKY%${INFILE_2}%" ${DEF_FILE_WK1} 
sed -i -e "s%:IDO_FILE%${INFILE_WRK}%"     ${DEF_FILE_WK1} 

#
#- マッチング
#
ZTLOUTFILE=${OUTFILE_WRK}
export ZTLOUTFILE
wait
${G_TOOLSH}/util/bin/ZTLMAT01 ${DEF_FILE_WK1}

rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " Matching Error($SVC matching:rc=$rc) "
    echo $JOBNAME " Matching Error($SVC matching:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

#
#- CSVマッチングの結果ファイルから3項目目と4項目目が異なる物を抽出する
#
bsortex -record recform=txtflt fldsep=, \
    -input reclen=30 file=${OUTFILE_WRK} include="2.1asc.ne.3.1asc" \
    -output file=${OUTFILE} \
    reconst=0.12,3.1

rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " SORT Error($SVC sort:rc=$rc) "
    echo $JOBNAME " SORT Error($SVC sort:rc=$rc) "
    exit ${G_RTN_ERROR}
fi

# ワーク削除
if [ ${WK_RM} = "true" ] ;then 
    rm -f ${INFILE_WRK}
    rm -f ${OUTFILE_WRK}
    rm -f ${DEF_FILE_WK1}
fi

#
#--- ジョブの終了メッセージを出力する
#
sh ${G_TOOLSH}/EOK010210J0.sh CS00028I $JOBNAME
sh ${G_TOOLSH}/EOK010210J0.sh CS00026I $JOBNAME

exit ${G_RTN_NORMAL}
