1、创建查询oracle的sql脚本文件,名为cx.sql,其中定义了三个变量
LAST_DATE昨天的时间
TODAY:今天的时间
FILE_NAME:导出的文件名
&1、&2、&3 表示后面使用的shell脚本调用cx.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 ****
from table_name
where
b.updatedate>=to_date('&LAST_DATE 9:00','yyyy-mm-dd hh24:mi') and b.updatedate
order by fee;
spool off;
exit
2、使用shell脚本调用该sql脚本
在导入数据这里向cx.sql传递了三个参数,分别是昨天的日期、今天的日期、导出数据的文件名,并通过sendEmail将导出文件通过附件发送给用户
#!/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 @"cx.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 [email protected] -t [email protected]
-s smtp.exmail.qq.com -u "标题" -o message-content-type=html
-o message-charset=utf8 -a /home/oracle/jfcx/${LAST_DATE}_${TODAY}.tar.gz -xu [email protected]
-xp send_pass -m "正文"
茶杯头甜蜜终章dlc 官方手机版v1.0.0.3
下载火柴人传说暗影格斗内置菜单 最新版v3.0.1
下载荒野乱斗测试服 安卓版v61.10.3
下载荒野乱斗彩虹服 安卓版v61.10.3
下载寒霜启示录 安卓版v1.25.10
寒霜启示录是一款生存模拟游戏,不少玩家可能对于末日都有着自己
末日城堡免广告版 安卓最新版v0.7.1
末日城堡免广告版是一款非常好玩的模拟经营类游戏,内部可以不看
甜蜜人生模拟器 最新版v1.4.5
甜蜜人生模拟器是一款非常好玩的模拟恋爱手游,玩家在这里能够对
武器锻造师内置功能菜单 v10.4
武器锻造师内置菜单版是游戏的破解版本,在该版本中为玩家提供了
开放空间overfield 安卓版v1.0.5
开放空间Overfield是一款箱庭养成经营手游,让你在广阔