利用Windows中自带的定时任务为oracle数据库定时备份(附oracle数据库导出导入命令)

一、步骤

1、oracle数据库导出命令

2、将此命令做成.bat可执行文件

3、将此可执行文件放入Windows定时任务中

4、以上三步就已经完成数据库的定时备份工作,这一步顺便说一下如何将oracle数据库备份文件再还原到数据库中

二、实操

1、oracle数据库导出命令:

exp system/manager@orcl  file=d:\erds.dmp  owner=(erds);

        账户名  密码

以上命令的意思是:利用用户名为system的用户,导出用户名为erds的用户中的所有表、函数以及存储过程等,导出的文件名为erds.dmp,该文件会存储在d盘的根目录下。

注意:

  1. 导出任何dmp文件,我们都需要用一个有权限的用户导出(这里你可以简单的理解为用刚刚安装数据库时系统自带的用户比如:sys用户、system用户)
  2. 黑窗口直接输入命令

 2、将上面的命令制作成.bat可执行程序:

        很简单,新建一个文本文档,然后把上面的数据库导出命令复制进去,回车再加一句exit;然后保存,然后将文本文档的扩展名改成.bat 改完之后双击它,他就会直接打开黑窗口执行数据库导出命令。如下图:

 

 

3、将此可执行文件放到Windows定时任务中

直接上图:

附件——系统工具中有一个任务计划程序,点开它

点击创建基本任务,一直下一步就可以了

下一步

选择你第2步做的bat启动程序,然后完成就ok了。

三、结束

通过上面的操作,数据库中的数据就能实现每天定时备份,如果需要将备份的数据还原到数据库中,请按以下操作:

1、将数据库备份产生的dmp文件的导入到oracle数据库中

imp erds/1@orcl file=d:\erds.dmp  full=y  ignore=y  log=d:\daochu.log

以上命令的意思是将d盘中的erds.dmp文件,“导入到用户名为erds的用户中“(这里加了引号,原因往下看),full=y为全部导入,ignore=y 为忽略一些错误,log=d:\daochu.log 导出日志。

erds.dmp中的所有内容的所有者(owner)是erds这个用户,那么问题来了,如果我执行如下语句会发生什么?

imp erds_new/1@orcl file=d:\erds.dmp  full=y  ignore=y  log=d:\daochu.log

执行这句话之后表不会导入到erds_new 用户中,而是会继续导入到erds用户中(因为erds.dmp中的所有内容的所有者(owner)是erds这个用户的),那么如何解决?如下

imp erds_new/1@orcl file=d:\erds.dmp  fromuser=erds touser=erds_new   ignore=y  log=d:\daochu.log

fromuser:旧的拥有者

touser:新的拥有者

从这些命令可以看出 imp后面跟的用户名并不是用来指定导入的目标用户的,它仅仅是一个拥有导入权限的用户而已,所以最上面对命令解释上我有一句加了引号。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 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"
好的,我可以回答你关于 Oracle 导入导出命令的问题,并且提供一个数据库每天定时备份的脚本。 首先,Oracle 提供了两个主要的工具用于数据的导入导出: 1. exp(Export):用于将 Oracle 数据库的数据导出到一个平面文件。 2. imp(Import):用于将一个平面文件的数据导入Oracle 数据库。 以下是这两个命令的基本语法: 导出数据到平面文件: ``` exp 用户名/密码@数据库名 file=导出文件名.dmp tables=要导出的表名 ``` 导入数据到数据库: ``` imp 用户名/密码@数据库名 file=导入文件名.dmp full=y ``` 其,`用户名/密码@数据库名` 指的是要导入/导出Oracle 数据库的连接信息;`file=` 指定导出/导入的文件名;`tables=` 指定要导出的表名;`full=y` 表示导入整个数据库。 另外,还有一些其他的参数可以用于导出/导入数据,可以通过 `exp help=y` 和 `imp help=y` 命令查看详细的用法和参数说明。 至于每天定时备份脚本,可以使用以下脚本: ``` #!/bin/bash # 设置备份文件名和路径 backup_dir=/backup/oracle backup_file=oracle_$(date +%Y%m%d_%H%M%S).dmp # 导出整个数据库 exp username/password@database full=y file=$backup_dir/$backup_file # 删除超过7天的备份文件 find $backup_dir -type f -name 'oracle_*.dmp' -mtime +7 -exec rm -f {} \; ``` 这个脚本会将整个数据库导出到一个以当前时间命名的备份文件,并将备份文件保存在指定的路径下。同时,还会删除超过7天的备份文件,以免占用过多的磁盘空间。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值