自定义脚本读取文本文件信息导出dmp

8 篇文章 0 订阅
6 篇文章 0 订阅

 通过自定义文本及条件导出表

::自动导出数据脚本
::此脚本用来导出一个数据表为一个dmp文件

::获取当天日期,格式YYYYMMDD
set "Today=%date:~,4%%date:~5,2%%date:~8,2%"

::如果存在该目录先删除该目录,以支持重跑
if exist %Today% rmdir /s /q %Today%

::数据库连接字符串
set Connect_String=brhfr/brhfr@oraORSS

md %Today%

set TableList=

if exist createTable.sql del createTable.sql

if exist dropTable.sql del dropTable.sql

setlocal enabledelayedexpansion
echo 1
for /F "tokens=1-3 delims=#" %%a IN ('type tablelst.txt') do (
    echo %%a
	if "%%a"=="table" echo create table temp_%%b as select * from %%b;>%Today%/create%%bTable.sql
	if "%%a"=="sql"   echo create table temp_%%b as %%c;>%Today%/create%%bTable.sql
     echo quit>>%Today%/create%%bTable.sql
	 sqlplus !Connect_String! @%Today%/create%%bTable.sql
	 
	 exp !Connect_String! tables=temp_%%b direct=Y buffer=40960 file=%Today%\temp_%%b.dmp log=%Today%\temp_%%b.log
 
	 echo drop table temp_%%b;>%Today%/drop%%bTable.sql
	 echo quit>>%Today%/drop%%bTable.sql
	 sqlplus !Connect_String! @%Today%/drop%%bTable.sql
)

配置文件tablelst.txt

第一列sql或者table

第二列为表明

第三列为导出条件

sql#ZSLP_CTIS_ITC_HIS#SELECT * FROM ZSLP_CTIS_ITC_HIS WHERE APPG_DATE = 20150630

table#BOCS_CUSM#
table#BOCS_CUSVAA#
table#BOCS_CUSVCC#
table#BOCS_INVE#
table#BOCS_XREF#
table#BOCS_BORM#
table#BOCS_ACSN#
table#BOCS_INVM#
table#BOCS_INVS#
sql#CTIS_IMC#SELECT * FROM CTIS_IMC WHERE APPG_DATE >= 20150630
sql#ZSLP_CTIS_IMC_HIS#SELECT * FROM ZSLP_CTIS_IMC_HIS WHERE APPG_DATE >= 20150630
table#CTIS_ISC#
sql#ZSLP_CTIS_ISC_HIS#SELECT * FROM ZSLP_CTIS_ISC_HIS WHERE APPG_DATE >= 20150630
sql#CTIS_ITC#SELECT * FROM CTIS_ITC WHERE APPG_DATE >= 20150630
sql#ZSLP_CTIS_ITC_HIS#SELECT * FROM ZSLP_CTIS_ITC_HIS WHERE APPG_DATE >= 20150630
table#ZSLP_CUSINFO#
table#ZSLP_CUS_EMAIL_MAP#


sql#CTIS_IMC#SELECT * FROM CTIS_IMC WHERE APPG_DATE <= 20150331 and appg_date>=20150101
sql#ZSLP_CTIS_IMC_HIS#SELECT * FROM ZSLP_CTIS_IMC_HIS WHERE APPG_DATE <= 20150331 and appg_date>=20150101
table#CTIS_ISC#
sql#ZSLP_CTIS_ISC_HIS#SELECT * FROM ZSLP_CTIS_ISC_HIS WHERE APPG_DATE <= 20150331 and appg_date>=20150101
sql#CTIS_ITC#SELECT * FROM CTIS_ITC WHERE APPG_DATE <= 20150331 and appg_date>=20150101
sql#ZSLP_CTIS_ITC_HIS#SELECT * FROM ZSLP_CTIS_ITC_HIS WHERE APPG_DATE <= 20150331 and appg_date>=20150101

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1、提供了oracle数据库备份脚本导出dmp文件 2、定时任务由操作系统提供的支持,在操作系统中设置定时任务,由操作系统定期执行脚本 3、补充。压缩包脚本有点问题,不能删除旧的备份文件。需要自动删除历史备份文件请用最新脚本: @echo off @echo ================================================ @echo windows环境下Oracle数据库的自动备份脚本 @echo 说明:启动备份时,需要配置以下变量 @echo 1、BACKUP_DIR 指定要备份到哪个目录 @echo 2、ORACLE_USERNAME 指定备份所用的Oracle用户名 @echo 3、ORACLE_PASSWORD 指定备份所用的Oracle密码 @echo 4、ORACLE_DB 指定备份所用的Oracle连接名 @echo 5、BACK_OPTION 备份选项,可以为空,可以为full=y,可以为owner=a用户,b用户 等等.... @echo 6、RAR_CMD 指定RAR命令行压缩工具所在目录 @echo ================================================ rem 以下变量需要根据实际情况配置 set BACKUP_DIR=D:\tools\oracle_bak\backup230 set ORACLE_USERNAME=PLATADMIN set ORACLE_PASSWORD=123456 set ORACLE_DB=ORCL set BACK_OPTION=owner=PLATADMIN set RAR_CMD="D:/Program Files/WinRAR/Rar.exe" rem for /f "tokens=1,2" %%a in ('date/t') do set TODAY=%%a rem set BACK_NAME=%ORACLE_DB%_%TODAY%(%time:~0,2%时%time:~3,2%分)_ set BACK_NAME=%Date:~0,4%%Date:~5,2%%Date:~8,2%%Time:~0,2%%Time:~3,2%%Time:~6,2% set BACK_FULL_NAME=%BACKUP_DIR%/%BACK_NAME% rem 开始备份 exp %ORACLE_USERNAME%/%ORACLE_PASSWORD%@%ORACLE_DB% %BACK_OPTION% file="%BACK_FULL_NAME%.dmp" log="%BACK_FULL_NAME%exp.log" rem 压缩并删除原有文件 %RAR_CMD% a -df "%BACK_FULL_NAME%back.rar" "%BACK_FULL_NAME%.dmp" "%BACK_FULL_NAME%exp.log" rem 删除15天前的备份文件 forfiles /p %BACKUP_DIR% /s /m *.rar /d -15 /c "cmd /c del @file"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值