Oracle数据备份

Oracle数据备份

提示:使用的是数据泵进行操作

一、数据泵是什么?

几乎所有DBA都熟悉oracle的导出和导入实用程序,它们将数据装载进或卸载出数据库,在oracle database 10g和11g中,你必须使用更通用更强大的数据泵导出和导入(Data Pump Export and Import)实用程序导出和导入数据。

二、使用步骤

步骤如下(示例):
1:使用管理员用户登陆 sys as sysdba
2 : 查看现有的逻辑目录 select * from dba_directories;
3:创建逻辑目录 create directory data_back_all as ‘E:/databack/backall’;
4:对逻辑目录的使用授权 grant read,write on directory data_back_all to 用户名;
5:导出数据 : $ expdp 用户名/密码@orcl dumpfile=backalldata.dmp directory=data_back_all full=y logfile=expdp.log;
($符号不能少)
6:导入数: $ impdp 用户名/密码 table_exists_action=append directory=data_back_all dumpfile=backalldata.dmp

注意 table_exists_action配置:

skip 是如果已存在表,则跳过并处理下一个对象,创建表并命名

append 是为表增加数据;

truncate 是截断表,然后为其增加新数据;

replace 是删除已存在表,重新建表并追加数据;

总结

实践总结:

数据泵导出的速度没有导入的速度快,同时在导出的时候可以根据很多条件导出,包括导出某个表,某个表空间,根据查询条件导出,下面给出一些语句:
1:按表空间
$ expdp 用户名/密码@orcl dumpfile=tsoper.dmp tablespaces=TS_OPER logfile=日志.log directory=data_back_all
2:某个表的查询条件
$ expdp 用户名/密码@orcl directory=data_back_all dumpfile=数据文件.dmp logfile=日志.log tables=表名 query=表名:" WHERE 条件";
实例:
$ expdp 用户名/密码@orcl directory=data_back_all dumpfile=edoc_file_object_relation_other.dmp logfile=edoc_file_object_relation_other.log tables=edoc_file_object_relation query=edoc_file_object_relation:" WHERE OBJ_TYPE!=‘com.haiyisoft.entity.gps.GnssPhotoInfo’ or Obj_type is null";

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

余额充值