#!/bin/bash
##############################################################
# システム名    ：eo顧客基幹システム
#
# サブシステム名：料金管理
#
# シェル名      ：利用料金情報（契約項目情報）ソート
#
# 機能          ：ＥＭ利用料金情報（契約項目）をソートする
#
#　　SORT順
#　　　料金コースコード＞料金サービスコード＞相対区分＞料金項目コード＞サービス解約理由（昇順）
#
#
# コマンド形式  ：EO30S0155J0.sh
#
# 実行環境      ：.../app/shl
#
# 終了ステータス：ゼロ以外異常
#
# 特記事項      ：特になし
#
# 変更履歴      ：変更日      変更者       障害／仕様変更No.
# v3.00           2012/06/26  FJ）山下     ST2-2012-0001216水平対応
# v4.01           2013/03/23  FJ）広野    【ST4-2013-0000405】性能改善 bsortパラメータの指定サイズ最適化
# v5.00           2013/09/27  FJ）伊藤    【OM-2013-0002478】抽出条件の追加、入力ファイルの変更。
# v8.00           2013/12/28  FJ）狭間     【ANK-1794-00-00】ファイルレイアウトの変更に伴い、サービス詳細識別番号を追加
##############################################################

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

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

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

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

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

#
#---OPD
#
OPD=$1

#
#---業務で必要な変数定義
#
#xxx=xxxxxxx
##############################################################
# 業務処理
##############################################################
sh ${G_TOOLSH}/EOK010210J0.sh CS00025I $JOBNAME

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

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

#
#---ＳＯＲＴ	サービス番号（昇順）＞料金コースコード（昇順）＞料金項目コード（昇順）＞課金終了日（降順）
#
bsort -s -z300 -Tflt -t, -5.20asca,9.3asca,11.11asca,33.8ascr -o ${MID_DIR_AC}/ACIFM252002.csv ${MID_DIR_AC}/ACIFM252001.csv 

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

#
#---ＳＯＲＴ	サービス番号（昇順）＞料金コースコード（昇順）＞料金項目コード（昇順）内の１レコード目の課金終了日を除去して出力
#
bsortex \
    -merge key="5.20asc,9.3asc,11.11asca" \
    -input reclen=300 file=${MID_DIR_AC}/ACIFM252002.csv \
    -record recform=txtcsv \
    -summary suppress first \
    -output reconst=0.10,1.6,2.14,3.12,4.11,5.20,6.12,7.1,8.2,9.3,10.12,11.11,12.2,13.12,14.8,15.8,16.8,17.8,18.8,19.2,20.8,21.2,22.2,23.1,24.2,25.1,26.2,27.4,28.4,29.1,30.10,31.12,32.3,34.30 \
            file=${MID_DIR_AC}/ACIFM057012.csv

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

#
#---ＳＯＲＴ	料金コースコード＞料金サービスコード＞相対区分＞料金項目コード＞サービス解約理由（昇順）
#
bsort -s -z300 -Tflt -t, -9.3asca,10.12asca,23.1asca,11.11asca,19.2asca -o ${MID_DIR_AC}/ACIFM057006.csv ${MID_DIR_AC}/ACIFM057012.csv 

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

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

exit ${G_RTN_NORMAL}
