oracle中导出查询结果,sqlplus导出oracle查询结果

这篇博客介绍了如何通过创建SQL脚本和Shell脚本来自动化查询Oracle数据库,并将结果导出为报表。脚本接收参数,包括昨天和今天的日期以及导出文件名,然后生成HTML报表。最后,通过Shell脚本打包数据并使用sendEmail发送带有附件的邮件给指定用户。
摘要由CSDN通过智能技术生成

经常要定期查询一些oracle中的数据并导出成报表,每次都手动操作实在麻烦,而且oracle安装在Linux上让非专业人员操作实在不放心,并且服务器在机房没法使用图形化工具连接去查询,即使可以通过客户端工具(例如plsql)别人也懒的学,再加上程序员更懒,写个查询的界面都要撤一堆屁话。还是要靠我们这些最勤劳的运维。

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

and a.isquery=1 and a.currintfee>=0 and b.currintegral>=5200 and b.currintegral<=30000

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 send@test.com -t receive@test.com \

-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 send@test.com \

-xp send_pass -m "正文"

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值