#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：契約管理
#
# シェル名      ：開始済テレビ主契約特定処理
#
# 機能          ：１、開始済テレビ主契約を特定する。
#
# コマンド形式  ：EO2DB0153J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# V7.00.00       20140210     AS)新居      OM-2014-0000611
#                                          サービス契約番号内で主契約となる内訳レコードを一意に特定する
# V7.00.01       20140218     AS)新居      OM-2014-0000169
#                                          翌月課金終了条件削除（OM-70前に戻す）
# v8.00.00       2014/06/02   FJ)岡田      TAI-2014-0000019
# v15.00.00      2015/08/31   FJ)中村      OM-2015-0002143
# v22.00.00      2016/01/25   FJ)福山      OM-2016-0000285 性能改善
# v23.00.00      2016/03/15   FJ)丹羽      OM-2016-0000638
# v23.00.01      2016/03/18   FJ)丹羽      OM-2016-0000638
# v23.00.02      2016/03/22   FJ)丹羽      OM-2016-0000638
# v74.00.00      2024/12/03   FJ) 吉田     【ANK-4592-00-00】テレビ新コース（スカパー用）導入対応）
#
##############################################################

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

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

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

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

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

#
#---業務で必要な変数定義
#
#xxx=xxxxxxx
# OM-2016-0000285 性能改善 2016/01/25 福山 ADD START
#---マッチング処理でLeftjoinがNULL時に"を付けなくする（マッチング使用時は必須）
export ZTLQUOTES=''
# OM-2016-0000285 性能改善 2016/01/25 福山 ADD END
##############################################################
# 業務処理
##############################################################
sh ${G_TOOLSH}/EOK010210J0.sh CS00025I $JOBNAME

#
#---運用日付取得
#
if [ "${OPD}" = "" ]; then
   . EOK010310J0.sh "BDATE"
else
   RSLT_OPEDATE="${OPD}"
fi

#
#--- ファイル定義
#

TIGFILE=${MID_DIR_KK}/KKIFM506001.csv

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

#
#---料金計算日、月初、月末の設定
#
while read LINE;
do
    TIG_YMD=(`echo $LINE | cut -d ',' -f 1 | sed -e "s/[^0-9]//g"`)
    STA_YMD=(`echo $LINE | cut -d ',' -f 2 | sed -e "s/[^0-9]//g"`)
    END_YMD=(`echo $LINE | cut -d ',' -f 3 | sed -e "s/[^0-9]//g"`)
    ZEN_END_YMD=(`echo $LINE | cut -d ',' -f 4 | sed -e "s/[^0-9]//g"`)
done < $TIGFILE

TIG=`date -d "$TIG_YMD" '+%s'`
STA=`date -d "$STA_YMD" '+%s'`
END=`date -d "$END_YMD" '+%s'`
ZEN=`date -d "$ZEN_END_YMD" '+%s'`
RST=`date -d "$RSLT_OPEDATE" '+%s'`

#
#---月初～料金計算日以前の場合、運用月前月が対象
#
if [ $RST -ge $STA ] 
then
    if [ $RST -le $TIG ]
    then
        TIG_MONTH=`echo $ZEN_END_YMD |cut -c 1-6`
    fi
fi

#
#---料金計算日翌日以降～月末の場合、運用月が対象
#
if [ $RST -gt $TIG ] 
then
    if [ $RST -le $END ]
    then
        TIG_MONTH=`echo $TIG_YMD |cut -c 1-6`
    fi
fi

#
#---次月を取得
#
OPEDATE_STADAY=${TIG_MONTH}"01"
NDATE=`date -d "1 month ${OPEDATE_STADAY}" +'%Y%m%d'`
NXTDATE_YYYYMM=`echo ${NDATE} |cut -c 1-6`

EDAY=`date -d "1 day ago ${NDATE}" +'%d'`
OPEDATE_ENDDAY=`echo ${OPEDATE_STADAY} |cut -c 1-6`${EDAY}

# debug
debug_p () {
    DEBUG_FLG=1
    if [ ${DEBUG_FLG} -eq 1 ]
    then
        echo "[debug] $1"
    fi
}

debug_p "RSLT_OPEDATE  :${RSLT_OPEDATE}"
debug_p "OPEDATE_STADAY:${OPEDATE_STADAY}"
debug_p "OPEDATE_ENDDAY:${OPEDATE_ENDDAY}"
debug_p "TIG_MONTH:${TIG_MONTH}"
debug_p "NXTDATE_YYYYMM:${NXTDATE_YYYYMM}"

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

P1="OPD=,"
P2="SVCCTL=,"
P3="JOB=EO2DB0153J0,"
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

#
#---""ダブルクォート付与
#---料金計算対象サービス契約情報
#
##入力ファイルの改行コード変換(CRLF→LF)
#▼▼▼TAI-2014-0000019▼▼▼
#nkf -Lu  < ${MID_DIR_KK}/KKIFM019551_00.csv > ${MID_DIR_KK}/KKIFM019551_00tmp.csv

#sed -i -e 's/,/\",\"/g' ${MID_DIR_KK}/KKIFM019551_00tmp.csv
#sed -i -e 's/^/\"/g' ${MID_DIR_KK}/KKIFM019551_00tmp.csv
#sed -i -e 's/$/\"/g' ${MID_DIR_KK}/KKIFM019551_00tmp.csv

#cat ${MID_DIR_KK}/KKIFM019551_00tmp.csv > ${MID_DIR_KK}/KKIFM019552_00tmp1.csv
##中間ファイルの削除
#rm ${MID_DIR_KK}/KKIFM019551_00tmp.csv
# OM-2016-0000285 性能改善 2016/01/25 福山 MOD START
#nkf -Lu  < ${LOC_DIR_KK}/KKIFM019551_00.csv > ${LOC_DIR_KK}/KKIFM019551_00tmp.csv

#sed -i -e 's/,/\",\"/g' ${LOC_DIR_KK}/KKIFM019551_00tmp.csv
#sed -i -e 's/^/\"/g' ${LOC_DIR_KK}/KKIFM019551_00tmp.csv
#sed -i -e 's/$/\"/g' ${LOC_DIR_KK}/KKIFM019551_00tmp.csv
bsortex -copy -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM019551_00.csv reclen=600 \
        -output file=${LOC_DIR_KK}/KKIFM019552_00tmp1.csv linedlmt=lf
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " SORT Error($SVC sort:rc=$rc file=${LOC_DIR_KK}/KKIFM019552_00tmp1.csv) " 
    echo $JOBNAME " SORT Error($SVC sort:rc=$rc file=${LOC_DIR_KK}/KKIFM019552_00tmp1.csv) "
    exit ${G_RTN_ERROR}
fi
# OM-2016-0000285 性能改善 2016/01/25 福山 MOD END

# OM-2016-0000285 性能改善 2016/01/25 福山 DEL START
#cat ${MID_DIR_KK}/KKIFM019551_00tmp.csv > ${LOC_DIR_KK}/KKIFM019552_00tmp1.csv
##中間ファイルの削除
#rm ${LOC_DIR_KK}/KKIFM019551_00tmp.csv
#▲▲▲TAI-2014-0000019▲▲▲

#rc=$?
#if [ $rc -ne 0 ]
#then
#    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " CAT Error($SVC cat:rc=$rc) "
#    echo $JOBNAME " CAT Error($SVC cat:rc=$rc) "
#    exit ${G_RTN_ERROR}
#fi
# OM-2016-0000285 性能改善 2016/01/25 福山 DEL END

#
#--- 抽出条件（サービスコード=ＴＶ("03"）
#

#▼▼▼TAI-2014-0000019▼▼▼
#bsortex -sort key=1.10asca,7.12asca -record recform=txtcsv -input file=${MID_DIR_KK}/KKIFM019552_00tmp1.csv reclen=600 \
#include="2.2asc.eq.'03'.and.(4.3asc.ne.'A23'.and.4.3asc.ne.'A37'.and.4.3asc.ne.'A75')" -output file=${MID_DIR_KK}/KKIFM019552_00.csv \
# OM-2015-0002143 2015/08/31 中村 料金IF性能改善 MOD START
#bsortex -sort key=1.10asca,7.12asca -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM019552_00tmp1.csv reclen=600 \
#include="2.2asc.eq.'03'.and.(4.3asc.ne.'A23'.and.4.3asc.ne.'A37'.and.4.3asc.ne.'A75')" -output file=${LOC_DIR_KK}/KKIFM019552_00.csv \
# ANK-4592-00-00 MOD START
#bsortex -copy -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM019552_00tmp1.csv reclen=600 \
#include="2.2asc.eq.'03'.and.(4.3asc.ne.'A23'.and.4.3asc.ne.'A37'.and.4.3asc.ne.'A75')" -output file=${LOC_DIR_KK}/KKIFM019552_00.csv \
bsortex -copy -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM019552_00tmp1.csv reclen=600 \
include="2.2asc.eq.'03'.and.(4.3asc.ne.'A23'.and.4.3asc.ne.'A37'.and.4.3asc.ne.'A75'.and.4.3asc.ne.'AC0'.and.4.3asc.ne.'AC1')" -output file=${LOC_DIR_KK}/KKIFM019552_00.csv \
# ANK-4592-00-00 MOD END
# OM-2015-0002143 2015/08/31 中村 料金IF性能改善 MOD END
#▲▲▲TAI-2014-0000019▲▲▲

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

#
#--- 抽出条件（サービスコード=ＴＶ("03"）以外
#

#▼▼▼TAI-2014-0000019▼▼▼
#bsortex -sort key=1.10asca,7.12asca -record recform=txtcsv -input file=${MID_DIR_KK}/KKIFM019552_00tmp1.csv reclen=600 \
#omit="2.2asc.eq.'03'.and.(4.3asc.ne.'A23'.and.4.3asc.ne.'A37'.and.4.3asc.ne.'A75')" -output file=${MID_DIR_KK}/KKIFM019552_00tmp2.csv \
# OM-2015-0002143 2015/08/31 中村 料金IF性能改善 MOD START
#bsortex -sort key=1.10asca,7.12asca -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM019552_00tmp1.csv reclen=600 \
#omit="2.2asc.eq.'03'.and.(4.3asc.ne.'A23'.and.4.3asc.ne.'A37'.and.4.3asc.ne.'A75')" -output file=${LOC_DIR_KK}/KKIFM019552_00tmp2.csv \
# ANK-4592-00-00 MOD START
#bsortex -copy -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM019552_00tmp1.csv reclen=600 \
#omit="2.2asc.eq.'03'.and.(4.3asc.ne.'A23'.and.4.3asc.ne.'A37'.and.4.3asc.ne.'A75')" -output file=${LOC_DIR_KK}/KKIFM019552_00tmp2.csv \
bsortex -copy -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM019552_00tmp1.csv reclen=600 \
omit="2.2asc.eq.'03'.and.(4.3asc.ne.'A23'.and.4.3asc.ne.'A37'.and.4.3asc.ne.'A75'.and.4.3asc.ne.'AC0'.and.4.3asc.ne.'AC1')" -output file=${LOC_DIR_KK}/KKIFM019552_00tmp2.csv \
# ANK-4592-00-00 MOD END
# OM-2015-0002143 2015/08/31 中村 料金IF性能改善 MOD END
#▲▲▲TAI-2014-0000019▲▲▲

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

#
#--- ファイル定義
#
DEFFILE=${G_TOOLSH}/util/def/KK_CM_0390.def
TMPDEFFILE=${ULD_WORK_DIR}/KK_CM_0390.tmp.${JOBNAME}.def
#▼▼▼TAI-2014-0000019▼▼▼
#OUTFILE=${MID_DIR_KK}/KKIFM019553_00.csv
OUTFILE=${LOC_DIR_KK}/KKIFM019553_00.csv
#▲▲▲TAI-2014-0000019▲▲▲
#
#--- 定義ファイル環境変数設定処理
#
cat ${DEFFILE} > ${TMPDEFFILE}
#▼▼▼TAI-2014-0000019▼▼▼
#sed -i -e s@'${MID_DIR_KK}'@${MID_DIR_KK}@g ${TMPDEFFILE}
sed -i -e s@'${LOC_DIR_KK}'@${LOC_DIR_KK}@g ${TMPDEFFILE}
#▲▲▲TAI-2014-0000019▲▲▲

#
#--- ファイルマッチング処理（サービス契約内訳より世代登録時分秒を取得）
#
# OM-2016-0000285 性能改善 2016/01/25 福山 ADD START
#マッチングに必要な項目のみ抽出
bsortex -copy -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM294002_crnt.csv reclen=280 \
         reconst="0.12,1.17,4.6" \
        -output file=${MID_DIR_KK}/EO2DB0153J0_KKIFM294002_crnt_tmp.csv
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " SORT Error($SVC sort:rc=$rc file=${LOC_DIR_KK}/KKIFM294002_crnt.csv) " 
    echo $JOBNAME " SORT Error($SVC sort:rc=$rc file=${LOC_DIR_KK}/KKIFM294002_crnt.csv) "
    exit ${G_RTN_ERROR}
fi
###2016/03/18 OM-2016-0000638 丹羽 MOD START
#sed -e "s/\"//g" ${MID_DIR_KK}/EO2DB0153J0_KKIFM294002_crnt_tmp.csv > ${LOC_DIR_KK}/KKIFM294002_crnt_plan_gene_dtm.csv
sed -e "s/\"//g" ${MID_DIR_KK}/EO2DB0153J0_KKIFM294002_crnt_tmp.csv > ${LOC_DIR_KK}/KKIFM294002_crnt_plan_gene_dtm.csv
###2016/03/18 OM-2016-0000638 丹羽 MOD END

##中間ファイルの削除
rm ${MID_DIR_KK}/EO2DB0153J0_KKIFM294002_crnt_tmp.csv
# OM-2016-0000285 性能改善 2016/01/25 福山 ADD END
export ZTLOUTFILE=${OUTFILE}
${G_TOOLSH}/util/bin/ZTLMAT01 ${TMPDEFFILE}

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

#
# １～４の優先順位を設定
#
#--- 抽出条件（３：翌月課金開始 and （課金終了日が末日））
#

#▼▼▼TAI-2014-0000019▼▼▼
#INFILE=${MID_DIR_KK}/KKIFM019553_00.csv
#TMPFILE3=${MID_DIR_KK}/KKIFM019553_00tmp3.csv
INFILE=${LOC_DIR_KK}/KKIFM019553_00.csv
TMPFILE3=${LOC_DIR_KK}/KKIFM019553_00tmp3.csv
#▲▲▲TAI-2014-0000019▲▲▲

###2016/03/15 OM-2016-0000638 丹羽 MOD START
#bsortex -sort key=1.10asca,7.12asca -record recform=txtcsv -input file=${INFILE} reclen=600 \
#include="20.1asc.ge.'0'.and.21.1asc.ge.'0'.and.20.6asc.eq.'${NXTDATE_YYYYMM}'.and.21.8asc.eq.'${OPEDATE_ENDDAY}'" -output file=${TMPFILE3} \
#reconst="0.2,1.10,2.2,3.2,4.3,5.6,6.12,7.12,8.12,9.12,10.12,11.12,12.12,13.12,14.12,15.12,16.12,17.10,18.8,19.8,20.8,21.8,22.8,23.4,24.1,25.1,26.8,27.2,28.8,29.8,30.8,31.8,32.8,33.8,34.5,35.11,36.100,37.2,38.8,39.1,40.8,41.1,42.8,43.8,44.14,45.8,46.17,47.17,48.17,49.2,50.12,'3'.1ascA"
bsortex -sort key=1.10asca,7.12asca -record recform=txtcsv -input file=${INFILE} reclen=600 \
include="20.1asc.ge.'0'.and.21.1asc.ge.'0'.and.20.6asc.eq.'${NXTDATE_YYYYMM}'.and.21.8asc.eq.'${OPEDATE_ENDDAY}'" -output file=${TMPFILE3} \
reconst="0.2,1.10,2.2,3.2,4.3,5.6,6.12,7.12,8.12,9.12,10.12,11.12,12.12,13.12,14.12,15.12,16.12,17.10,18.8,19.8,20.8,21.8,22.8,23.4,24.1,25.1,26.8,27.2,28.8,29.8,30.8,31.8,32.8,33.8,34.5,35.11,36.100,37.2,38.8,39.1,40.8,41.1,42.8,43.8,44.14,45.8,46.17,47.17,48.17,49.2,50.12,'3'.1asc"
###2016/03/15 OM-2016-0000638 丹羽 MOD END

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

#
#--- 抽出条件（１：当月課金中 and （課金開始 <= 課金終了） and 課金終了日>=翌月））
# OM-2014-0000070 （課金終了日(21,6) >= NXTDATE_YYYYMM）条件追加
#--- 抽出条件（１：当月課金中 and （課金開始 <= 課金終了））
# OM-2014-0000169 （課金終了日(21,6) >= NXTDATE_YYYYMM）条件削除
#

#▼▼▼TAI-2014-0000019▼▼▼
#TMPFILE1=${MID_DIR_KK}/KKIFM019553_00tmp1.csv
TMPFILE1=${LOC_DIR_KK}/KKIFM019553_00tmp1.csv
#▲▲▲TAI-2014-0000019▲▲▲

###2016/03/15 OM-2016-0000638 丹羽 MOD START
#bsortex -sort key=1.10asca,7.12asca -record recform=txtcsv -input file=${INFILE} reclen=600 \
#include="20.1asc.ge.'0'.and.21.1asc.ge.'0'.and.20.8asc.le.'${OPEDATE_ENDDAY}'.and.21.8asc.ge.'${OPEDATE_STADAY}'.and.20.8asc.le.21.8asc" -output file=${TMPFILE1} \
#reconst="0.2,1.10,2.2,3.2,4.3,5.6,6.12,7.12,8.12,9.12,10.12,11.12,12.12,13.12,14.12,15.12,16.12,17.10,18.8,19.8,20.8,21.8,22.8,23.4,24.1,25.1,26.8,27.2,28.8,29.8,30.8,31.8,32.8,33.8,34.5,35.11,36.100,37.2,38.8,39.1,40.8,41.1,42.8,43.8,44.14,45.8,46.17,47.17,48.17,49.2,50.12,'1'.1ascA"
bsortex -sort key=1.10asca,7.12asca -record recform=txtcsv -input file=${INFILE} reclen=600 \
include="20.1asc.ge.'0'.and.21.1asc.ge.'0'.and.20.8asc.le.'${OPEDATE_ENDDAY}'.and.21.8asc.ge.'${OPEDATE_STADAY}'.and.20.8asc.le.21.8asc" -output file=${TMPFILE1} \
reconst="0.2,1.10,2.2,3.2,4.3,5.6,6.12,7.12,8.12,9.12,10.12,11.12,12.12,13.12,14.12,15.12,16.12,17.10,18.8,19.8,20.8,21.8,22.8,23.4,24.1,25.1,26.8,27.2,28.8,29.8,30.8,31.8,32.8,33.8,34.5,35.11,36.100,37.2,38.8,39.1,40.8,41.1,42.8,43.8,44.14,45.8,46.17,47.17,48.17,49.2,50.12,'1'.1asc"
###2016/03/15 OM-2016-0000638 丹羽 MOD END

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

#
#--- 抽出条件（２：翌月課金開始 and （課金開始 <= 課金終了））
#

#▼▼▼TAI-2014-0000019▼▼▼
#TMPFILE2=${MID_DIR_KK}/KKIFM019553_00tmp2.csv
TMPFILE2=${LOC_DIR_KK}/KKIFM019553_00tmp2.csv
#▲▲▲TAI-2014-0000019▲▲▲

###2016/03/15 OM-2016-0000638 丹羽 MOD START
#bsortex -sort key=1.10asca,7.12asca -record recform=txtcsv -input file=${INFILE} reclen=600 \
#include="20.1asc.ge.'0'.and.21.1asc.ge.'0'.and.20.6asc.eq.'${NXTDATE_YYYYMM}'.and.20.8asc.le.21.8asc" -output file=${TMPFILE2} \
#reconst="0.2,1.10,2.2,3.2,4.3,5.6,6.12,7.12,8.12,9.12,10.12,11.12,12.12,13.12,14.12,15.12,16.12,17.10,18.8,19.8,20.8,21.8,22.8,23.4,24.1,25.1,26.8,27.2,28.8,29.8,30.8,31.8,32.8,33.8,34.5,35.11,36.100,37.2,38.8,39.1,40.8,41.1,42.8,43.8,44.14,45.8,46.17,47.17,48.17,49.2,50.12,'2'.1ascA"
bsortex -sort key=1.10asca,7.12asca -record recform=txtcsv -input file=${INFILE} reclen=600 \
include="20.1asc.ge.'0'.and.21.1asc.ge.'0'.and.20.6asc.eq.'${NXTDATE_YYYYMM}'.and.20.8asc.le.21.8asc" -output file=${TMPFILE2} \
reconst="0.2,1.10,2.2,3.2,4.3,5.6,6.12,7.12,8.12,9.12,10.12,11.12,12.12,13.12,14.12,15.12,16.12,17.10,18.8,19.8,20.8,21.8,22.8,23.4,24.1,25.1,26.8,27.2,28.8,29.8,30.8,31.8,32.8,33.8,34.5,35.11,36.100,37.2,38.8,39.1,40.8,41.1,42.8,43.8,44.14,45.8,46.17,47.17,48.17,49.2,50.12,'2'.1asc"
###2016/03/15 OM-2016-0000638 丹羽 MOD END

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

#
#--- その他（１：２：３：以外）
# OM-2014-0000070 抽出条件（１に（課金終了日(21,6) >= NXTDATE_YYYYMM）条件追加
# OM-2014-0000169 抽出条件（１の（課金終了日(21,6) >= NXTDATE_YYYYMM）条件削除
#

#▼▼▼TAI-2014-0000019▼▼▼
#TMPFILE4=${MID_DIR_KK}/KKIFM019553_00tmp4.csv
TMPFILE4=${LOC_DIR_KK}/KKIFM019553_00tmp4.csv
#▲▲▲TAI-2014-0000019▲▲▲

###2016/03/15 OM-2016-0000638 丹羽 MOD START
#bsortex -sort key=1.10asca,7.12asca -record recform=txtcsv -input file=${INFILE} reclen=600 \
#omit="20.1asc.ge.'0'.and.21.1asc.ge.'0'.and.((20.6asc.eq.'${NXTDATE_YYYYMM}'.and.21.8asc.eq.'${OPEDATE_ENDDAY}').or.(20.8asc.le.'${OPEDATE_ENDDAY}'.and.21.8asc.ge.'${OPEDATE_STADAY}'.and.20.8asc.le.21.8asc).or.(20.6asc.eq.'${NXTDATE_YYYYMM}'.and.20.8asc.le.21.8asc))" \
#-output file=${TMPFILE4} \
#reconst="0.2,1.10,2.2,3.2,4.3,5.6,6.12,7.12,8.12,9.12,10.12,11.12,12.12,13.12,14.12,15.12,16.12,17.10,18.8,19.8,20.8,21.8,22.8,23.4,24.1,25.1,26.8,27.2,28.8,29.8,30.8,31.8,32.8,33.8,34.5,35.11,36.100,37.2,38.8,39.1,40.8,41.1,42.8,43.8,44.14,45.8,46.17,47.17,48.17,49.2,50.12,'4'.1ascA"
bsortex -sort key=1.10asca,7.12asca -record recform=txtcsv -input file=${INFILE} reclen=600 \
omit="20.1asc.ge.'0'.and.21.1asc.ge.'0'.and.((20.6asc.eq.'${NXTDATE_YYYYMM}'.and.21.8asc.eq.'${OPEDATE_ENDDAY}').or.(20.8asc.le.'${OPEDATE_ENDDAY}'.and.21.8asc.ge.'${OPEDATE_STADAY}'.and.20.8asc.le.21.8asc).or.(20.6asc.eq.'${NXTDATE_YYYYMM}'.and.20.8asc.le.21.8asc))" \
-output file=${TMPFILE4} \
reconst="0.2,1.10,2.2,3.2,4.3,5.6,6.12,7.12,8.12,9.12,10.12,11.12,12.12,13.12,14.12,15.12,16.12,17.10,18.8,19.8,20.8,21.8,22.8,23.4,24.1,25.1,26.8,27.2,28.8,29.8,30.8,31.8,32.8,33.8,34.5,35.11,36.100,37.2,38.8,39.1,40.8,41.1,42.8,43.8,44.14,45.8,46.17,47.17,48.17,49.2,50.12,'4'.1asc"
###2016/03/15 OM-2016-0000638 丹羽 MOD END

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

#
#---テレビ主契約内訳番号ファイル作成（KKIFM468001_00.csv）
#
# ②サービス契約内訳で主契約の特定
#
#▼▼▼TAI-2014-0000019▼▼▼
#TMPFILE5=${MID_DIR_KK}/KKIFM019553_00tmp5.csv
#TMPFILE6=${MID_DIR_KK}/KKIFM019553_00tmp6.csv
#TMPFILE=${MID_DIR_KK}/KKIFM468002_00tmp.csv
TMPFILE5=${LOC_DIR_KK}/KKIFM019553_00tmp5.csv
TMPFILE6=${LOC_DIR_KK}/KKIFM019553_00tmp6.csv
TMPFILE=${LOC_DIR_KK}/KKIFM468002_00tmp.csv
#▲▲▲TAI-2014-0000019▲▲▲

#
#---ＳＯＲＴマージ
#
bsortex -sort key=7.12asca -record recform=txtcsv -input file=${TMPFILE1},${TMPFILE2},${TMPFILE3},${TMPFILE4} reclen=600 -output file=${TMPFILE5}

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

#
#---主契約のみ抽出
# OM-2014-0000070 ソート条件に課金開始日を追加
# OM-2014-0000169 ソート優先順の項目位置変更
#--- キー項目(サービス契約内訳（昇順）優先順（降順）課金開始日（昇順）課金終了日（昇順）世代登録年月日時分秒)でソート
# 抽出条件
#    料金プランコード（５番目）NULL以外
#
bsortex -sort key=7.12asca,51.1ascr,20.8asca,21.8asca,46.17asca -record recform=txtcsv -input file=${TMPFILE5} reclen=600 include="5.1asc.ge.'0'" -output file=${TMPFILE6}

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

#
#--- マージ
# OM-2014-0000070 reconstに課金開始日を追加
# OM-2014-0000169 reconstの優先順の項目位置変更
#
#▼TV主契約修正▼
#bsortex -merge key=7.12asca -record recform=txtcsv -input file=${TMPFILE6} reclen=600 -summary suppress last -output file=${TMPFILE} reconst="5.6,1.10,7.12,4.3"
bsortex -merge key=7.12asca -record recform=txtcsv -input file=${TMPFILE6} reclen=600 -summary suppress last -output file=${TMPFILE} reconst="5.6,1.10,7.12,4.3,51.1,21.8,46.17,20.8"
#▲TV主契約修正▲

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
###2016/03/15 OM-2016-0000638 丹羽 DEL START
##--- ダブルコーテーションを削除する
##▼▼▼TAI-2014-0000019▼▼▼
##sed -e "s/\"//g" ${MID_DIR_KK}/KKIFM468002_00tmp.csv  > ${MID_DIR_KK}/KKIFM468002_00tmp1.csv
###出力ファイルの改行コード変換(LF→CRLF)
##nkf -Lw  < ${MID_DIR_KK}/KKIFM468002_00tmp1.csv > ${MID_DIR_KK}/KKIFM468002_00tmp2.csv
###中間ファイルの削除
##rm ${MID_DIR_KK}/KKIFM468002_00tmp1.csv
#sed -e "s/\"//g" ${LOC_DIR_KK}/KKIFM468002_00tmp.csv  > ${LOC_DIR_KK}/KKIFM468002_00tmp1.csv
###出力ファイルの改行コード変換(LF→CRLF)
#nkf -Lw  < ${LOC_DIR_KK}/KKIFM468002_00tmp1.csv > ${LOC_DIR_KK}/KKIFM468002_00tmp2.csv
###中間ファイルの削除
#rm ${LOC_DIR_KK}/KKIFM468002_00tmp1.csv
##▲▲▲TAI-2014-0000019▲▲▲
###2016/03/15 OM-2016-0000638 丹羽 DEL END

###2016/03/22 OM-2016-0000638 丹羽 DEL START
#rc=$?
#if [ $rc -ne 0 ]
#then
#    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " MV Error($SVC mv:rc=$rc) "
#    echo $JOBNAME " sed Error($SVC mv:rc=$rc) "
#    exit ${G_RTN_ERROR}
#fi
###2016/03/22 OM-2016-0000638 丹羽 DEL END

#
#---主契約のみ抽出
# 抽出条件
#    料金プランコード６桁目（"1"or"3"or"5"）を抽出
# OM-2014-0000070 reclenを80⇒90へ
#
#▼TV主契約修正▼
#bsortex -sort key=0.10asca -record recform=txtfix -input file=${MID_DIR_KK}/KKIFM468002_00tmp2.csv include="5.1asc.eq.'1'.or.5.1asc.eq.'3'.or.5.1asc.eq.'5'" reclen=50 -output file=${MID_DIR_KK}/KKIFM468002_00tmp3.csv 
#▼▼▼TAI-2014-0000019▼▼▼
#bsortex -sort key=7.10asca -record recform=txtfix -input file=${MID_DIR_KK}/KKIFM468002_00tmp2.csv include="5.1asc.eq.'1'.or.5.1asc.eq.'3'.or.5.1asc.eq.'5'" reclen=90 -output file=${MID_DIR_KK}/KKIFM468002_00tmp3.csv
###2016/03/15 OM-2016-0000638 丹羽 MOD START
#bsortex -sort key=7.10asca -record recform=txtfix -input file=${LOC_DIR_KK}/KKIFM468002_00tmp2.csv include="5.1asc.eq.'1'.or.5.1asc.eq.'3'.or.5.1asc.eq.'5'" reclen=90 -output file=${LOC_DIR_KK}/KKIFM468002_00tmp3.csv
bsortex -sort key=7.10asca -record recform=txtfix -input file=${LOC_DIR_KK}/KKIFM468002_00tmp.csv include="5.1asc.eq.'1'.or.5.1asc.eq.'3'.or.5.1asc.eq.'5'" reclen=90 -output file=${LOC_DIR_KK}/KKIFM468002_00tmp3.csv
###2016/03/15 OM-2016-0000638 丹羽 MOD END
#▲▲▲TAI-2014-0000019▲▲▲
#▲TV主契約修正▲

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

#▼TV主契約修正▼
#
# ③サービス契約で主契約の特定
#
# OM-2014-0000070 ソート条件に課金開始日を追加
#--- キー項目(サービス契約（昇順）優先順（降順）課金開始日（昇順）課金終了日（昇順）世代登録年月日時分秒（昇順）)でソート
#
#▼▼▼TAI-2014-0000019▼▼▼
#bsortex -sort key=1.10asca,4.1ascr,7.8asca,5.8asca,6.17asca -record recform=txtcsv -input file=${MID_DIR_KK}/KKIFM468002_00tmp3.csv reclen=90 -output file=${MID_DIR_KK}/KKIFM468002_00tmp4.csv
bsortex -sort key=1.10asca,4.1ascr,7.8asca,5.8asca,6.17asca -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM468002_00tmp3.csv reclen=90 -output file=${LOC_DIR_KK}/KKIFM468002_00tmp4.csv
#▲▲▲TAI-2014-0000019▲▲▲

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

#
#--- マージ
# OM-2014-0000070 reclenを80⇒90へ
#
#▼▼▼TAI-2014-0000019▼▼▼
#bsortex -merge key=1.10asca -record recform=txtcsv -input file=${MID_DIR_KK}/KKIFM468002_00tmp4.csv reclen=90 -summary suppress last -output file=${MID_DIR_KK}/KKIFM468002_00tmp5.csv reconst="0.6,1.10,2.12,3.3"
bsortex -merge key=1.10asca -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM468002_00tmp4.csv reclen=90 -summary suppress last -output file=${LOC_DIR_KK}/KKIFM468002_00tmp5.csv reconst="0.6,1.10,2.12,3.3"
#▲▲▲TAI-2014-0000019▲▲▲

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
#▲TV主契約修正▲

#
#--- ソート
#
#▼TV主契約修正▼
#bsortex -sort key=1.10asca -record recform=txtcsv -input file=${MID_DIR_KK}/KKIFM468002_00tmp3.csv reclen=50 -output file=${MID_DIR_KK}/KKIFM468002_00.csv reconst="1.10,2.12,3.3,0.6"
#▼▼▼TAI-2014-0000019▼▼▼
#bsortex -sort key=1.10asca -record recform=txtcsv -input file=${MID_DIR_KK}/KKIFM468002_00tmp5.csv reclen=50 -output file=${MID_DIR_KK}/KKIFM468002_00.csv reconst="1.10,2.12,3.3,0.6"
###2016/03/18 OM-2016-0000638 丹羽 MOD START
#bsortex -sort key=1.10asca -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM468002_00tmp5.csv reclen=50 -output file=${LOC_DIR_KK}/KKIFM468002_00.csv reconst="1.10,2.12,3.3,0.6"
bsortex -sort key=1.10asca -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM468002_00tmp5.csv reclen=50 -output file=${LOC_DIR_KK}/KKIFM468002_00.csv reconst="1.10,2.12,3.3,0.6" linedlmt=crlf
###2016/03/18 OM-2016-0000638 丹羽 MOD END
#▲▲▲TAI-2014-0000019▲▲▲
#▲TV主契約修正▲

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

#
#---""ダブルクォート付与
#---テレビ主契約内訳番号ファイル
#
##入力ファイルの改行コード変換(CRLF→LF)
#▼▼▼TAI-2014-0000019▼▼▼
#nkf -Lu  < ${MID_DIR_KK}/KKIFM468002_00.csv > ${MID_DIR_KK}/KKIFM468002_00tmp6.csv

#sed -i -e 's/,/\",\"/g' ${MID_DIR_KK}/KKIFM468002_00tmp6.csv
#sed -i -e 's/^/\"/g' ${MID_DIR_KK}/KKIFM468002_00tmp6.csv
#sed -i -e 's/$/\"/g' ${MID_DIR_KK}/KKIFM468002_00tmp6.csv

#cat ${MID_DIR_KK}/KKIFM468002_00tmp6.csv > ${MID_DIR_KK}/KKIFM468002_00tmp7.csv
##中間ファイルの削除
#rm ${MID_DIR_KK}/KKIFM468002_00tmp6.csv
###2016/03/15 OM-2016-0000638 丹羽 DEL START
#nkf -Lu  < ${LOC_DIR_KK}/KKIFM468002_00.csv > ${LOC_DIR_KK}/KKIFM468002_00tmp6.csv
###2016/03/15 OM-2016-0000638 丹羽 DEL END

###2016/03/15 OM-2016-0000638 丹羽 DEL START
#sed -i -e 's/,/\",\"/g' ${LOC_DIR_KK}/KKIFM468002_00tmp6.csv
#sed -i -e 's/^/\"/g' ${LOC_DIR_KK}/KKIFM468002_00tmp6.csv
#sed -i -e 's/$/\"/g' ${LOC_DIR_KK}/KKIFM468002_00tmp6.csv
###2016/03/15 OM-2016-0000638 丹羽 DEL END

###2016/03/15 OM-2016-0000638 丹羽 DEL START
#cat ${LOC_DIR_KK}/KKIFM468002_00tmp6.csv > ${LOC_DIR_KK}/KKIFM468002_00tmp7.csv
###2016/03/15 OM-2016-0000638 丹羽 DEL END

###2016/03/15 OM-2016-0000638 丹羽 DEL START
###中間ファイルの削除
#rm ${LOC_DIR_KK}/KKIFM468002_00tmp6.csv
###2016/03/15 OM-2016-0000638 丹羽 DEL END
#▲▲▲TAI-2014-0000019▲▲▲

###2016/03/18 OM-2016-0000638 丹羽 DEL START
#rc=$?
#if [ $rc -ne 0 ]
#then
#    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " CAT Error($SVC cat:rc=$rc) "
#    echo $JOBNAME " CAT Error($SVC cat:rc=$rc) "
#    exit ${G_RTN_ERROR}
#fi
###2016/03/18 OM-2016-0000638 丹羽 DEL END
###2016/03/18 OM-2016-0000638 丹羽 ADD START
bsortex -copy -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM468002_00.csv reclen=50 \
        -output file=${LOC_DIR_KK}/KKIFM468002_00tmp7.csv linedlmt=lf
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " SORT Error($SVC sort:rc=$rc file=${LOC_DIR_KK}/KKIFM468002_00.csv) " 
    echo $JOBNAME " SORT Error($SVC sort:rc=$rc file=${LOC_DIR_KK}/KKIFM468002_00.csv) "
    exit ${G_RTN_ERROR}
fi
###2016/03/18 OM-2016-0000638 丹羽 ADD END
#
# ①翌月課金開始の課金終了日逆転パターンの課金終了日引き延ばし対象の特定
#
#---ＳＯＲＴマージ（５：１：、２：の主契約ファイル作成）
#    料金プランコード（NULL）以外を抽出
#
#▼▼▼TAI-2014-0000019▼▼▼
#TMPFILE7=${MID_DIR_KK}/KKIFM019553_00tmp7.csv
TMPFILE7=${LOC_DIR_KK}/KKIFM019553_00tmp7.csv
#▲▲▲TAI-2014-0000019▲▲▲

bsortex -sort key=7.12asca -record recform=txtcsv -input file=${TMPFILE1},${TMPFILE2} reclen=600 include="5.1asc.ge.'0'" -output file=${TMPFILE7} \
reconst="5.6,0.2,1.10,2.2,3.2,4.3,6.12,7.12,8.12,9.12,10.12,11.12,12.12,13.12,14.12,15.12,16.12,17.10,18.8,19.8,20.8,21.8,22.8,23.4,24.1,25.1,26.8,27.2,28.8,29.8,30.8,31.8,32.8,33.8,34.5,35.11,36.100,37.2,38.8,39.1,40.8,41.1,42.8,43.8,44.14,45.8,46.17,47.17,48.17,49.2,50.12,51.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

#
# 抽出条件
#    料金プランコード６桁目（"1"or"3"or"5"）を抽出
#
#▼▼▼TAI-2014-0000019▼▼▼
#TMPFILE8=${MID_DIR_KK}/KKIFM019553_00tmp8.csv
TMPFILE8=${LOC_DIR_KK}/KKIFM019553_00tmp8.csv
#▲▲▲TAI-2014-0000019▲▲▲

###2016/03/15 OM-2016-0000638 丹羽 MOD START
#bsortex -sort key=15.10asca -record recform=txtfix -input file=${TMPFILE7} include="6.1asc.eq.'1'.or.6.1asc.eq.'3'.or.6.1asc.eq.'5'" reclen=600 -output file=${TMPFILE8}
bsortex -sort key=10.10asca -record recform=txtfix -input file=${TMPFILE7} include="5.1asc.eq.'1'.or.5.1asc.eq.'3'.or.5.1asc.eq.'5'" reclen=600 -output file=${TMPFILE8}
###2016/03/15 OM-2016-0000638 丹羽 MOD END
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

#
#--- ファイル定義
#
DEFFILE=${G_TOOLSH}/util/def/KK_CM_0396.def
TMPDEFFILE=${ULD_WORK_DIR}/KK_CM_0396.tmp.${JOBNAME}.def
#▼▼▼TAI-2014-0000019▼▼▼
#OUTFILE=${MID_DIR_KK}/KKIFM019554_00.csv
OUTFILE=${LOC_DIR_KK}/KKIFM019554_00.csv
#▲▲▲TAI-2014-0000019▲▲▲
#
#--- 定義ファイル環境変数設定処理
#
cat ${DEFFILE} > ${TMPDEFFILE}
#▼▼▼TAI-2014-0000019▼▼▼
#sed -i -e s@'${MID_DIR_KK}'@${MID_DIR_KK}@g ${TMPDEFFILE}
sed -i -e s@'${LOC_DIR_KK}'@${LOC_DIR_KK}@g ${TMPDEFFILE}
#▲▲▲TAI-2014-0000019▲▲▲

#
#--- ファイルマッチング処理（翌月課金開始のみかつ課金開始終了日の逆転データ特定）
#
export ZTLOUTFILE=${OUTFILE}
${G_TOOLSH}/util/bin/ZTLMAT01 ${TMPDEFFILE}

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

#
#---３： 翌月課金開始のみかつ課金開始終了日の逆転データを抽出
#--- キー項目(サービス契約内訳、世代登録年月日時分秒)でソート
# 抽出条件
#    51項目NULL,52項目NULL,54項目NULL
#

#▼▼▼TAI-2014-0000019▼▼▼
#bsortex -sort key=7.12asca,46.17asca -record recform=txtcsv -input file=${MID_DIR_KK}/KKIFM019554_00.csv reclen=600 \
#omit="51.1asc.ge.'0'.or.52.1asc.ge.'0'.or.54.1asc.ge.'0'" -output file=${MID_DIR_KK}/KKIFM019555_00tmp.csv \
#reconst="0.6,1.2,2.10,3.2,4.2,5.3,6.12,7.12,8.12,9.12,10.12,11.12,12.12,13.12,14.12,15.12,16.12,17.10,18.8,19.8,20.8,21.8,22.8,23.4,24.1,25.1,26.8,27.2,28.8,29.8,30.8,31.8,32.8,33.8,34.5,35.11,36.100,37.2,38.8,39.1,40.8,41.1,42.8,43.8,44.14,45.8,46.17,47.17,48.17,'99'.2ascA,50.12",53.12
###2016/03/15 OM-2016-0000638 丹羽 MOD START
#bsortex -sort key=7.12asca,46.17asca -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM019554_00.csv reclen=600 \
#omit="51.1asc.ge.'0'.or.52.1asc.ge.'0'.or.54.1asc.ge.'0'" -output file=${LOC_DIR_KK}/KKIFM019555_00tmp.csv \
#reconst="0.6,1.2,2.10,3.2,4.2,5.3,6.12,7.12,8.12,9.12,10.12,11.12,12.12,13.12,14.12,15.12,16.12,17.10,18.8,19.8,20.8,21.8,22.8,23.4,24.1,25.1,26.8,27.2,28.8,29.8,30.8,31.8,32.8,33.8,34.5,35.11,36.100,37.2,38.8,39.1,40.8,41.1,42.8,43.8,44.14,45.8,46.17,47.17,48.17,'99'.2ascA,50.12",53.12
bsortex -sort key=7.12asca,46.17asca -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM019554_00.csv reclen=600 \
omit="51.1asc.ge.'0'.or.52.1asc.ge.'0'.or.54.1asc.ge.'0'" -output file=${LOC_DIR_KK}/KKIFM019555_00tmp.csv \
reconst="0.6,1.2,2.10,3.2,4.2,5.3,6.12,7.12,8.12,9.12,10.12,11.12,12.12,13.12,14.12,15.12,16.12,17.10,18.8,19.8,20.8,21.8,22.8,23.4,24.1,25.1,26.8,27.2,28.8,29.8,30.8,31.8,32.8,33.8,34.5,35.11,36.100,37.2,38.8,39.1,40.8,41.1,42.8,43.8,44.14,45.8,46.17,47.17,48.17,'99'.2asc,50.12,53.12"
###2016/03/15 OM-2016-0000638 丹羽 MOD END
#▲▲▲TAI-2014-0000019▲▲▲

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

#
#--- キー項目(サービス契約内訳)でソートマージ、最新世代残す
#

#▼▼▼TAI-2014-0000019▼▼▼
#bsortex -merge key=7.12asca -record recform=txtcsv -input file=${MID_DIR_KK}/KKIFM019555_00tmp.csv reclen=600 -summary suppress last -output file=${MID_DIR_KK}/KKIFM019555_00tmp1.csv
bsortex -merge key=7.12asca -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM019555_00tmp.csv reclen=600 -summary suppress last -output file=${LOC_DIR_KK}/KKIFM019555_00tmp1.csv
#▲▲▲TAI-2014-0000019▲▲▲

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

#
#---ＳＯＲＴマージ
#    料金プランコード（NULL）を抽出
#
#▼▼▼TAI-2014-0000019▼▼▼
#TMPFILE9=${MID_DIR_KK}/KKIFM019555_00tmp2.csv

#bsortex -sort key=7.12asca -record recform=txtcsv -input file=${MID_DIR_KK}/KKIFM019555_00tmp1.csv reclen=600 omit="0.1asc.ge.'0'" -output file=${TMPFILE9}
TMPFILE9=${LOC_DIR_KK}/KKIFM019555_00tmp2.csv

bsortex -sort key=7.12asca -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM019555_00tmp1.csv reclen=600 omit="0.1asc.ge.'0'" -output file=${TMPFILE9}
#▲▲▲TAI-2014-0000019▲▲▲

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

#
#---ＳＯＲＴマージ
#    料金プランコード（NULL）以外を抽出
#
#▼▼▼TAI-2014-0000019▼▼▼
#TMPFILE10=${MID_DIR_KK}/KKIFM019555_00tmp3.csv

#bsortex -sort key=7.12asca -record recform=txtcsv -input file=${MID_DIR_KK}/KKIFM019555_00tmp1.csv reclen=600 include="0.1asc.ge.'0'" -output file=${TMPFILE10}
TMPFILE10=${LOC_DIR_KK}/KKIFM019555_00tmp3.csv

bsortex -sort key=7.12asca -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM019555_00tmp1.csv reclen=600 include="0.1asc.ge.'0'" -output file=${TMPFILE10}
#▲▲▲TAI-2014-0000019▲▲▲

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

#
# 抽出条件 （主契約以外ファイル作成）
#    料金プランコード６桁目（"1"or"3"or"5"）以外を抽出
#
#▼▼▼TAI-2014-0000019▼▼▼
#TMPFILE11=${MID_DIR_KK}/KKIFM019555_00tmp4.csv
TMPFILE11=${LOC_DIR_KK}/KKIFM019555_00tmp4.csv
#▲▲▲TAI-2014-0000019▲▲▲

###2016/03/15 OM-2016-0000638 丹羽 MOD START
#bsortex -sort key=15.10asca -record recform=txtfix -input file=${TMPFILE10} omit="6.1asc.eq.'1'.or.6.1asc.eq.'3'.or.6.1asc.eq.'5'" reclen=600 -output file=${TMPFILE11}
bsortex -sort key=10.10asca -record recform=txtfix -input file=${TMPFILE10} omit="5.1asc.eq.'1'.or.5.1asc.eq.'3'.or.5.1asc.eq.'5'" reclen=600 -output file=${TMPFILE11}
###2016/03/15 OM-2016-0000638 丹羽 MOD START

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

#
# 抽出条件　（主契約ファイル作成）
#    料金プランコード６桁目（"1"or"3"or"5"）を抽出
#
#▼▼▼TAI-2014-0000019▼▼▼
#TMPFILE12=${MID_DIR_KK}/KKIFM019555_00tmp5.csv
TMPFILE12=${LOC_DIR_KK}/KKIFM019555_00tmp5.csv
#▲▲▲TAI-2014-0000019▲▲▲

###2016/03/15 OM-2016-0000638 丹羽 MOD START
#bsortex -sort key=15.10asca -record recform=txtfix -input file=${TMPFILE10} include="6.1asc.eq.'1'.or.6.1asc.eq.'3'.or.6.1asc.eq.'5'" reclen=600 -output file=${TMPFILE12}
bsortex -sort key=10.10asca -record recform=txtfix -input file=${TMPFILE10} include="5.1asc.eq.'1'.or.5.1asc.eq.'3'.or.5.1asc.eq.'5'" reclen=600 -output file=${TMPFILE12}
###2016/03/15 OM-2016-0000638 丹羽 MOD END

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

#
# 抽出条件　（主契約ファイル）
#    サービス契約内訳が同一のデータを抽出
#
#▼▼▼TAI-2014-0000019▼▼▼
#TMPFILE13=${MID_DIR_KK}/KKIFM019555_00tmp6.csv
TMPFILE13=${LOC_DIR_KK}/KKIFM019555_00tmp6.csv
#▲▲▲TAI-2014-0000019▲▲▲

bsortex -sort key=2.10asca -record recform=txtcsv -input file=${TMPFILE12} include="7.12asc.eq.51.12asc" reclen=600 -output file=${TMPFILE13}

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

#
#---ＳＯＲＴマージ
#
#▼▼▼TAI-2014-0000019▼▼▼
#OUTFILE=${MID_DIR_KK}/KKIFM019555_00.csv
OUTFILE=${LOC_DIR_KK}/KKIFM019555_00.csv
#▲▲▲TAI-2014-0000019▲▲▲

bsortex -sort key=2.10asca -record recform=txtcsv -input file=${TMPFILE9},${TMPFILE11},${TMPFILE13} reclen=600 -output file=${OUTFILE} \
reconst="1.2,2.10,3.2,4.2,5.3,0.6,6.12,7.12,8.12,9.12,10.12,11.12,12.12,13.12,14.12,15.12,16.12,17.10,18.8,19.8,20.8,21.8,22.8,23.4,24.1,25.1,26.8,27.2,28.8,29.8,30.8,31.8,32.8,33.8,34.5,35.11,36.100,37.2,38.8,39.1,40.8,41.1,42.8,43.8,44.14,45.8,46.17,47.17,48.17,49.2,50.12,51.12"

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

#
#--- ファイル定義
#
DEFFILE=${G_TOOLSH}/util/def/KK_CM_0402.def
TMPDEFFILE=${ULD_WORK_DIR}/KK_CM_0402.tmp.${JOBNAME}.def
#▼▼▼TAI-2014-0000019▼▼▼
#OUTFILE=${MID_DIR_KK}/KKIFM019556_00tmp1.csv
OUTFILE=${LOC_DIR_KK}/KKIFM019556_00tmp1.csv
#▲▲▲TAI-2014-0000019▲▲▲
#
#--- 定義ファイル環境変数設定処理
#
cat ${DEFFILE} > ${TMPDEFFILE}
#▼▼▼TAI-2014-0000019▼▼▼
#sed -i -e s@'${MID_DIR_KK}'@${MID_DIR_KK}@g ${TMPDEFFILE}
sed -i -e s@'${LOC_DIR_KK}'@${LOC_DIR_KK}@g ${TMPDEFFILE}
#▲▲▲TAI-2014-0000019▲▲▲

#
#--- ファイルマッチング処理（特定した翌月課金開始のみかつ課金開始終了日の逆転データの"99"を元のファイルに設定）
#    サービス契約インターフェース作成へ（KKIFM019557_00.csv）
#
export ZTLOUTFILE=${OUTFILE}
${G_TOOLSH}/util/bin/ZTLMAT01 ${TMPDEFFILE}

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

#
#---ＳＯＲＴマージ（ＴＶ以外を元に戻す）
#
#▼▼▼TAI-2014-0000019▼▼▼
#bsortex -sort key=7.12asca -record recform=txtcsv -input file=${MID_DIR_KK}/KKIFM019556_00tmp1.csv,${MID_DIR_KK}/KKIFM019552_00tmp2.csv reclen=600 -output file=${MID_DIR_KK}/KKIFM019556_00.csv
# OM-2016-0000285 性能改善 2016/01/25 福山 MOD START
#bsortex -sort key=7.12asca -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM019556_00tmp1.csv,${LOC_DIR_KK}/KKIFM019552_00tmp2.csv reclen=600 -output file=${LOC_DIR_KK}/KKIFM019556_00.csv
bsortex -sort key=7.12asca -record recform=txtcsv -input file=${LOC_DIR_KK}/KKIFM019556_00tmp1.csv,${LOC_DIR_KK}/KKIFM019552_00tmp2.csv reclen=600 -output file=${LOC_DIR_KK}/KKIFM019557_00.csv linedlmt=crlf
# OM-2016-0000285 性能改善 2016/01/25 福山 MOD END
#▲▲▲TAI-2014-0000019▲▲▲

#--- ダブルコーテーションを削除する
#▼▼▼TAI-2014-0000019▼▼▼
#sed -e "s/\"//g" ${MID_DIR_KK}/KKIFM019556_00.csv  > ${MID_DIR_KK}/KKIFM019556_00tmp.csv
##出力ファイルの改行コード変換(LF→CRLF)
#nkf -Lw  < ${MID_DIR_KK}/KKIFM019556_00tmp.csv > ${MID_DIR_KK}/KKIFM019557_00.csv
##中間ファイルの削除
#rm ${MID_DIR_KK}/KKIFM019556_00tmp.csv
# OM-2016-0000285 性能改善 2016/01/25 福山 DEL START
#sed -e "s/\"//g" ${LOC_DIR_KK}/KKIFM019556_00.csv  > ${LOC_DIR_KK}/KKIFM019556_00tmp.csv
##出力ファイルの改行コード変換(LF→CRLF)
#nkf -Lw  < ${LOC_DIR_KK}/KKIFM019556_00tmp.csv > ${LOC_DIR_KK}/KKIFM019557_00.csv
##中間ファイルの削除
#rm ${LOC_DIR_KK}/KKIFM019556_00tmp.csv
# OM-2016-0000285 性能改善 2016/01/25 福山 DEL END
#▲▲▲TAI-2014-0000019▲▲▲
# OM-2016-0000285 性能改善 2016/01/25 福山 MOD START
#rc=$?
#if [ $rc -ne 0 ]
#then
#    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " MV Error($SVC mv:rc=$rc) "
#    echo $JOBNAME " sed Error($SVC mv:rc=$rc) "
#    exit ${G_RTN_ERROR}
#fi
rc=$?
if [ $rc -ne 0 ]
then
    sh ${G_TOOLSH}/EOK010210J0.sh CS00002E $JOBNAME " SORT Error($SVC sort:rc=$rc file=${LOC_DIR_KK}/KKIFM019557_00.csv) "
    echo $JOBNAME " SORT Error($SVC sort:rc=$rc file=${LOC_DIR_KK}/KKIFM019557_00.csv) "
    exit ${G_RTN_ERROR}
fi
# OM-2016-0000285 性能改善 2016/01/25 福山 MOD END

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

exit $exit_rc
