Oracle定时导出数据脚本编写

本文主要以Oracle导出自动处理为例,介绍Linux系统的自动定时处理的两个常见问题

一、自动导出处理脚本
#!/bin/bash
echo 'export data of test'
date
fmt=`date "+%Y-%m-%d[%HH%MM%SS]"`
exp system/password file=/opt/oracle/test"${fmt}".dmp PARFILE='/opt/oracle/ePFILE'
echo 'export data of test complete!'

二、如何处理带时间的文件名
定义shell变量
fmt=`date "+%Y-%m-%d[%HH%MM%SS]"`
输出与引用变量
"${fmt}"也可以用单引号可以查阅Shell相关资料
注意:1、``符号不是单引号,而是键盘TAB键上面的符号
      2、上面的格式中%表示输出日期格式,可以查询date命令的文档获得

三、如何是脚本自动运行

1.crontab 让脚本或程序定时周期性执行
使用权限 : 所有使用者
  
  使用方式 :
  
  crontab [ -u user ] file
  crontab [ -u user ] { -l | -r | -e }
  
  说明 :
  crontab 是用来让使用者在固定时间或固定间隔执行程序之用,换句话说,也就是类似使用者的时

程表。-u user 是指设定指定 user 的时程表,这个前提是你必须要有其权限(比如说是 root)才能够

指定他人的时程表。如果不使用 -u user 的话,就是表示设定自己的时程表。
  
  餐数 :
  
  -e : 执行文字编辑器来设定时程表,内定的文字编辑器是 VI,如果你想用别的文字编辑器,则请

先设定 VISUAL 环境变数来指定使用那个文字编辑器(比如说 setenv VISUAL joe)
  -r : 删除目前的时程表
  -l : 列出目前的时程表
  
  时程表的格式如下 :
   f1 f2 f3 f4 f5 program
  
  其中 f1 是表示分钟,f2 表示小时,f3 表示一个月份中的第几日,f4 表示月份,f5 表示一个星

期中的第几天。program 表示要执行的程序。
  当 f1 为 * 时表示每分钟都要执行 program,f2 为 * 时表示每小时都要执行程序,其馀类推
  当 f1 为 a-b 时表示从第 a 分钟到第 b 分钟这段时间内要执行,f2 为 a-b 时表示从第 a 到第

b 小时都要执行,其馀类推
  当 f1 为 */n 时表示每 n 分钟个时间间隔执行一次,f2 为 */n 表示每 n 小时个时间间隔执行

一次,其馀类推
  当 f1 为 a, b, c,... 时表示第 a, b, c,... 分钟要执行,f2 为 a, b, c,... 时表示第 a, b,

c...个小时要执行,其馀类推
  
  使用者也可以将所有的设定先存放在档案 file 中,用 crontab file 的方式来设定时程表。
  例子 :
  
  每月每天每小时的第 0 分钟执行一次 /bin/ls :
   0 7 * * * /bin/ls
  
  在 12 月内, 每天的早上 6 点到 12 点中,每隔 20 分钟执行一次 /usr/bin/backup :
   0 6-12/3 * 12 * /usr/bin/backup
  
  周一到周五每天下午 5:00 寄一封信给 youtops@gmail.com :
   0 17 * * 1-5 mail -s "hi" youtops@gmail.com< /tmp/maildata
  
  每月每天的午夜 0 点 20 分, 2 点 20 分, 4 点 20 分....执行 echo "you are right!"
   20 0-23/2 * * * echo "you are right!"
  
  注意 :
  
  当程序在你所指定的时间执行后,系统会寄一封信给你,显示该程序执行的内容,若是你不希望收

到这样的信,请在每一行空一格之后加上 > /dev/null 2>&1 即可

2.at命令仅让脚本或程序运行一次,由于at命令与windows下很类似的用法,就不介绍了

 

  • 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、付费专栏及课程。

余额充值