Oracleにsqlplusコマンドでselect結果をエクスポートして添付ファイルとして送信する

投稿者: | 2017年1月11日

1.queryora.sql
SET NEWPAGE 0
SET SPACE 0
SET LINESIZE 80
SET PAGESIZE 0
SET ECHO OFF
SET FEEDBACK OFF
SET VERIFY OFF
SET HEADING OFF
SET MARKUP HTML OFF SPOOL OFF
define LAST_DATE=’&1′
define TODAY=’&2′
define FILE_NAME=’&3′

set markup html on;
spool &3
#SELECT構文
select ****
from tblName
where
条件
spool off;
exit

2.shellコード
#!/bin/bash
#環境変数
export PATH
export EDITOR=vim
export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=/u01/app/oracle/product/11.2.0/dbhome_1
export ORACLE_SID=orcl
export ORACLE_UNQNAME=orcl
export ORACLE_HOSTNAME=db2
export PATH=$PATH:/$ORACLE_HOME/bin
export NLS_LANG=”SIMPLIFIED CHINESE_CHINA.UTF8″
alias sqlplus=’/usr/local/rlwrap/bin/rlwrap sqlplus’
alias rman=’/usr/local/rlwrap/bin/rlwrap rman’
export NLS_DATE_FORMAT=”YYYY-MM-DD HH24:MI:SS”
#パラメータの設定
LAST_DATE=`date -d”yesterday” +%Y-%m-%d`
TODAY=`date -d “today” +”%Y-%m-%d”`
FILE_NAME=”${LAST_DATE}_${TODAY}.html”

#データインポート
sqlplus oracle_user/oracle_pass @”queryora.sql” “$LAST_DATE” “$TODAY” “$FILE_NAME”
echo “query is finish”

#データ圧縮
tar -czvf ${LAST_DATE}_${TODAY}.tar.gz ${LAST_DATE}_${TODAY}.html
rm -rf ${LAST_DATE}_${TODAY}.html

#メール送信
/usr/local/bin/sendEmail -f send@sample -t receive@sample \
-s smtp.exmail.sample.com -u “タイトル” -o message-content-type=html \
-o message-charset=utf8 -a /home/oracle/daxiaju/${LAST_DATE}_${TODAY}.tar.gz -xu send@sample \
-xp send_pass -m “本文”