#!/bin/sh . /home/db2inst1/.profile #數據上報程序 #author huodaihao #得到系統 DATE=$(date +%Y%m%d) DATE_TIME=$(date +'%Y%m%d%H%M%S') ORG="Z2017112000011" DBNAME="pbctjuat" USERNAME="db2admin" PASSWORD="db2@admin" #shell文件目錄 SHELL_PATH=/home/tianjing/sh #csv文件基本路徑 CSV_PATH=/home/tianjing/csv #csv文件路徑永久路徑 CSV_SAVE_PATH=/home/tianjing/savecsv #日誌存放路徑 LOG_PATH=/home/tianjing/log #定義一個正在執行 TMPFILE=/home/tianjing/sh/shell_csv.tmp #檢查是否有其餘的實 if [ -e ${TMPFILE} ] then echo "Other instance is running!" exit 0 #退出本腳本的執行 else touch ${TMPFILE} #新建一個臨時文件 chmod 600 ${TMPFILE} fi #設置一個 rap "rm -f ${TMPFILE}; exit" 0 1 2 3 9 15 echo "`date +%Y-%m-%d\ %T` ------------START----------">>${LOG_PATH}/load_data_${DATE}.log #鏈接數據庫 輸出日誌信息 db2 connect to $DBNAME user $USERNAME using $PASSWORD echo "`date +%Y-%m-%d\ %T` -清空ods_temp下的T_SC_MERCHANT_INFO,T_SC_MERCHANT_IM_DETAIL,T_SC_MERCHANT_EX_DETAIL,T_RBYHZHXX表的數據">>${LOG_PATH}/load_data_${DATE}.log db2 "delete from ODS_TEMP.T_SC_MERCHANT_INFO " db2 "delete from ODS_TEMP.T_SC_MERCHANT_IM_DETAIL " db2 "delete from ODS_TEMP.T_SC_MERCHANT_EX_DETAIL " db2 "delete from ODS_TEMP.T_RBYHZHXX " db2 commit for file_all_name in ${CSV_PATH}/*.csv do echo "$file_all_name --------------" #獲取csv文件名稱 CSV_NAME=$(basename "$file_all_name") echo "$CSV_NAME----" echo "`date +%Y-%m-%d\ %T` csv文件的文件名稱是:${CSV_NAME}">>${LOG_PATH}/load_data_${DATE}.log # gbk --> utf-8 if file "${file_all_name}"|grep -q UTF-8 >/dev/null ; then echo "csv is utf-8" >> ${LOG_PATH}/load_data_${DATE}.log else echo "csv is gbk to utf-8 success" >> ${LOG_PATH}/load_data_${DATE}.log iconv -c -f gbk -t utf-8 ${file_all_name}> ${LOG_PATH}/temp_${CSV_NAME} rm -f ${file_all_name} mv ${LOG_PATH}/temp_${CSV_NAME} ${CSV_PATH}/${CSV_NAME} fi #截取1個字 FLAG=${CSV_NAME:0:6} ORG_CODE=${CSV_NAME:9:14} LOAD_DATE=${CSV_NAME:24:8} #商戶基本信息表 TEMPLATE_FILE_ID1='20160813173727372741975374175096280' #商戶入金支付明細 TEMPLATE_FILE_ID2='16081318351835185705507814252728000' #商戶出金支付明細 TEMPLATE_FILE_ID3='16081318360836823267029553581420000' #融寶商戶對應帳號的信息 TEMPLATE_FILE_ID4='16081318365236529830235585519220000' sed -i '1d' $file_all_name sed -i "s/\//-/g" $file_all_name if [ $FLAG = "SSJBXX" ] then db2 "update DPS.T_SYS_COLLECTION_LOG set VERIFY_STATUS=1 where FISCAL_TERM='${LOAD_DATE}' and ORG_ID='${ORG_CODE}' and TEMPLATE_FILE_ID='${TEMPLATE_FILE_ID1}'" echo "`date +%Y-%m-%d\ %T` load 商戶基本信息數據">>${LOG_PATH}/load_data_${DATE}.log echo "1111111111111111" #商戶基本信息 db2 "LOAD client FROM '${file_all_name}' OF DEL MODIFIED BY CODEPAGE=1208 COLDEL, DECPLUSBLANK DATESISO INSERT INTO ODS_TEMP.T_SC_MERCHANT_INFO NONRECOVERABLE " db2 commit fi if [ $FLAG = "SHRJMX" ] then db2 "update DPS.T_SYS_COLLECTION_LOG set VERIFY_STATUS=1 where FISCAL_TERM='${LOAD_DATE}' and ORG_ID='${ORG_CODE}' and TEMPLATE_FILE_ID='${TEMPLATE_FILE_ID2}'" echo "`date +%Y-%m-%d\ %T` load 入金支付明細">>${LOG_PATH}/load_data_${DATE}.log #入金支付明細 db2 "LOAD client FROM '${file_all_name}' OF DEL MODIFIED BY CODEPAGE=1208 COLDEL, DECPLUSBLANK DATESISO INSERT INTO ODS_TEMP.T_SC_MERCHANT_IM_DETAIL NONRECOVERABLE" db2 commit fi if [ $FLAG = "SSCJMX" ] then db2 "update DPS.T_SYS_COLLECTION_LOG set VERIFY_STATUS=1 where FISCAL_TERM='${LOAD_DATE}' and ORG_ID='${ORG_CODE}' and TEMPLATE_FILE_ID='${TEMPLATE_FILE_ID3}'" echo "`date +%Y-%m-%d\ %T` load 出金支付">>${LOG_PATH}/load_data_${DATE}.log #出金支付明細 db2 "LOAD client FROM '${file_all_name}' OF DEL MODIFIED BY CODEPAGE=1208 COLDEL, DECPLUSBLANK DATESISO INSERT INTO ODS_TEMP.T_SC_MERCHANT_EX_DETAIL NONRECOVERABLE" db2 commit fi if [ $FLAG = "RBYHXX" ] then db2 "update DPS.T_SYS_COLLECTION_LOG set VERIFY_STATUS=1 where FISCAL_TERM='${LOAD_DATE}' and ORG_ID='${ORG_CODE}' and TEMPLATE_FILE_ID='${TEMPLATE_FILE_ID4}'" echo "`date +%Y-%m-%d\ %T` load榮寶信息">>${LOG_PATH}/load_data_${DATE}.log #融寶銀行帳戶信息 db2 "LOAD client FROM '${CSV_PATH}/${CSV_NAME}' OF DEL MODIFIED BY CODEPAGE=1208 COLDEL, DECPLUSBLANK DATESISO INSERT INTO ODS_TEMP.T_RBYHZHXX NONRECOVERABLE" db2 commit fi mv -f ${CSV_PATH}/${CSV_NAME} ${CSV_SAVE_PATH} done echo "`date +%Y-%m-%d\ %T` load ods_temp success">>${LOG_PATH}/load_data_${DATE}.log db2 "update DPS.T_SYS_COLLECTION_LOG set VERIFY_STATUS=1 where FISCAL_TERM='${LOAD_DATE}' and ORG_ID='${ORG_CODE}' and TEMPLATE_FILE_ID='${TEMPLATE_FILE_ID1}'" db2 "update DPS.T_SYS_COLLECTION_LOG set VERIFY_STATUS=1 where FISCAL_TERM='${LOAD_DATE}' and ORG_ID='${ORG_CODE}' and TEMPLATE_FILE_ID='${TEMPLATE_FILE_ID2}'" db2 "update DPS.T_SYS_COLLECTION_LOG set VERIFY_STATUS=1 where FISCAL_TERM='${LOAD_DATE}' and ORG_ID='${ORG_CODE}' and TEMPLATE_FILE_ID='${TEMPLATE_FILE_ID3}'" db2 "update DPS.T_SYS_COLLECTION_LOG set VERIFY_STATUS=1 where FISCAL_TERM='${LOAD_DATE}' and ORG_ID='${ORG_CODE}' and TEMPLATE_FILE_ID='${TEMPLATE_FILE_ID4}'" db2 "call ODS.P_PAY_TYSHXX_WLJYMX('${LOAD_DATE}','${ORG_CODE}')" echo "`date +%Y-%m-%d\ %T` load ods success">>${LOG_PATH}/load_data_${DATE}.log db2 "call DW.P_PAY_TYSHXX('${LOAD_DATE}','${ORG_CODE}','','')" db2 "call DW.P_PAY_WLJYMX('${LOAD_DATE}','${ORG_CODE}','','')" echo "`date +%Y-%m-%d\ %T` load DW success">>${LOG_PATH}/load_data_${DATE}.log db2 commit; db2 terminate; rm -f ${TMPFILE}
#!/bin/sh #---------------------------------------------------- #功能:將文件上傳到FTP文件服務器 # #時間:2015-03-22 #---------------------------------------------------- #FTP地址 IP_ADDRESS="192.168.0.111" #FTP端存放目錄 REMOTE_PATH="/load_data/files/test_data" #shell存放目錄 BASE_PATH="/load_shell" #本地須要上傳的文件存放目錄 LOCAL_PATH="/home/pbc-file-maxfiles" #本地文件上傳後備份存放目錄 LOCAL_ZIP_PATH="/home/pbc-file-maxfiles/data_bak" #FTPP用戶名 USERNAME="db2inst1" #FTP密碼 PASSWORD="db2inst1" #獲取系統時間到天 DATE=$(date +%Y%m%d) #echo $DATE echo "`date +%Y-%m-%d\ %T` : ---------------------------START----------------------------------" >>$BASE_PATH/log/ftp_up_$DATE.log echo "`date +%Y-%m-%d\ %T` : 開始上傳文件" >>$BASE_PATH/log/ftp_up_$DATE.log ftp -in <<EOF open $IP_ADDRESS user $USERNAME $PASSWORD binary cd $REMOTE_PATH lcd $LOCAL_PATH espv4 off passive mput "*.csv" bye EOF echo "`date +%Y-%m-%d\ %T` : 上傳文件結束" >>$BASE_PATH/log/ftp_up_$DATE.log #獲取系統時間到天 #DATE=$(date +%Y%m) echo "`date +%Y-%m-%d\ %T` : 準備移動文件到 ${LOCAL_ZIP_PATH} 目錄 " >>$BASE_PATH/log/ftp_up_$DATE.log for file_all_zip_name in ${LOCAL_PATH}/*;do ZIP_FILE_NAME=$(basename "$file_all_zip_name") # temp_zip_file=$file_all_zip_name #截取文件名 TABLE_NAME_STR=${ZIP_FILE_NAME:0:4} ORG=${ZIP_FILE_NAME:4:14} DAY=${ZIP_FILE_NAME:18:8} MONTH=${ZIP_FILE_NAME:18:6} FILE_NAME=${ZIP_FILE_NAME:0:26} if [ ! -d "$LOCAL_ZIP_PATH/$MONTH" ]; then mkdir $LOCAL_ZIP_PATH/$MONTH fi # echo "`date +%Y-%m-%d\ %T` : 移動文件 ${ZIP_FILE_NAME}" >>$BASE_PATH/log/ftp_up_$DATE.log #將解壓完的文件從臨時文件夾移到永久保存文件夾 mv -f $temp_zip_file $LOCAL_ZIP_PATH/$MONTH done echo "`date +%Y-%m-%d\ %T` : 文件移動完畢" >>$BASE_PATH/log/ftp_up_$DATE.log #cd $LOCAL_ZIP_PATH #if [ ! -d "$LOCAL_ZIP_PATH/$DATE" ]; # then # mkdir $LOCAL_ZIP_PATH/$DATE #fi #mkdir $DATE #將解壓完的文件從臨時文件夾移到永久保存文件夾 #mv -f $LOCAL_PATH/* $LOCAL_ZIP_PATH/$DATE echo "`date +%Y-%m-%d\ %T` : ---------------------------END----------------------------------" >>$BASE_PATH/log/ftp_up_$DATE.log