oracle 数据库备份脚本

用管理员,备份不同用户的表数据

@echo off 
:: 以“YYYYMMDDHHmmss”格式取出当前时间。 
rem set filename=%date:~3,4%%date:~8,2%%date:~11,2%%time:~1,2%%time:~3,2%%time:~6,2%
set filename=%date:~3,4%%date:~8,2%%date:~11,2%
rem echo filename=%filename%
rem 数据库连接名
set USER=xxxxxx
rem 密码
set PASSWORD=xxxxxx
rem 数据库实例
set DATABASE=orcl
if not exist "E:\backup\data"  mkdir E:\backup\data
if not exist "E:\backup\log"   mkdir E:\backup\log
set DATADIR=E:\backup\data
set LOGDIR=E:\backup\log
rem 在Windows 配置定时任务时需要,否则报错文件找不到
set addr=cd /d %~dp0
rem echo %addr:~6%
set /P tableExp=<%addr:~6%table.txt
echo ================================================   
echo start backup  %tableExp%
echo ================================================
if "%tableExp%"=="" (
goto end
) else (
goto demo2
)
echo (%tableExp%)

:demo2
exp "'%USER%/%PASSWORD%@%DATABASE% as sysdba'" tables=(%tableExp%) file=%DATADIR%\data_%filename%.dmp log=%LOGDIR%\log_%filename%.log
goto end 
:end
rem echo end  .........

pause

将上述代码复制保存为xxx.bat文件

这里  table.txt 用来配置需要备份的表,格式为 用户名+.(英文点)+表名,表与表之间用逗号(英文)隔开。例如:bsitsqp.demo02_hs,bsitsqp.demo01_hs,viid.demo01_hs。这里备份了用户bsitsqp 的demo02_hs、demo01_hs表和用户 viid 的 demo01_hs 表。

注意:table.txt 必须与xxx.bat文件在同一目录下

如果要备份整个数据库,将上述代码中 tables=(%tableExp%) 去掉即可。

如果要备份特定用户的数据 ,修改用户名 密码即可。

如果需要定时备份,在Windows 中添加定时任务即可

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值