windows中oracle自动备份

一、创建一个目录,比如:oraclebackup

二、创建一个txt,比如:beifen.txt

三、在txt中写入备份脚本(网上参考的0.0):

@echo off   
echo ================================================   
echo  Windows环境下Oracle11.2g数据库的自动备份脚本  
echo  1. 使用data_当前日期命名备份文件。  
echo  2. 自动删除7天前的备份,防止文件越来越多。  
echo ================================================  

::以“YYYYMMDD”格式取出当前时间。  
set BACKUPDATE=%date:~0,4%%date:~5,2%%date:~8,2%%Time:~0,2%%Time:~3,2%%Time:~6,2%
::创建备份目录。  
if not exist "D:\oraclebackup\data"    mkdir D:\oraclebackup\data  
if not exist "D:\oraclebackup\log"     mkdir D:\oraclebackup\log  
set DATADIR=D:\oraclebackup\data
set LOGDIR=D:\oraclebackup\log
exp userid='mzd2/oracle@orcl'  file=%DATADIR%\data_%BACKUPDATE%.dmp log=%LOGDIR%\log_%BACKUPDATE%.log  
::删除7天前的备份。  
forfiles /p "%DATADIR%" /s /m *.* /d -7 /c "cmd /c del @path"  
forfiles /p "%LOGDIR%" /s /m *.* /d -7 /c "cmd /c del @path"  
exit

注意:

1、其中的mzd2为oracle中的用户名,oracle为密码,orcl为sid(也叫SERVICE_NAME)这个可以打开oracle安装目录,然后打开tnsnames.ora文件,获取SERVICE_NAME即可

这里写图片描述

这里写图片描述

2、注意其中目录的填写即可

四、保存之后将文件后缀改为.bat,然后双击运行一下,确认你的脚本能正常使用。

这里写图片描述

五、给windows制定一个计划任务:

1、打开控制面板,搜索“计划”

这里写图片描述

2、打开计划任务,创建基本任务

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

3、选择你刚写好的脚本,然后完成即可

问题一:EXP-00091: 正在导出有问题的统计信息。

这里写图片描述

解决方法:

1、oracle服务端与客户端的编码不同导致的。

2、打开sqlplus,登入系统管理员,然后输入命令:

select * from nls_database_parameters t where t.parameter=’NLS_CHARACTERSET’;

然后复制你的查询结果(一般为:CHINESE_CHINA.AL32UTF8),然后打开注册表,修改NLS_LANG即可。

这里写图片描述

注意:这样一改之后sqlplus将会变得乱码,不过这个并不影响,其实这个最开始导出来的也就是log看上去有问题,再次

导入的时候没什么影响。

问题二:空表无法备份。

备份出来的dmp重新导入数据库中发现少了好多张表,仔细看会发现都是空表。

解决方法:

参考于:https://www.cnblogs.com/ningvsban/p/3603678.html

1、查询空表:

select table_name from user_tables where NUM_ROWS=0;

2、拼接修改空表控件语句

select 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0

3、执行查询结果,然后再进行备份即可实现空表备份导出

  • 3
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以使用 Oracle 的自带工具 Data Pump 来实现自动备份。具体步骤如下: 1. 创建一个备份目录: ``` CREATE DIRECTORY backup_dir AS 'D:\backup'; ``` 2. 创建一个备份作业: ``` BEGIN DBMS_SCHEDULER.CREATE_JOB ( job_name => 'backup_job', job_type => 'EXPORT', job_action => 'SCHEMA_EXPORT', number_of_arguments => 3, start_date => SYSTIMESTAMP, repeat_interval => 'FREQ=DAILY;BYHOUR=23', job_class => 'DEFAULT_JOB_CLASS', auto_drop => FALSE, enabled => TRUE); DBMS_SCHEDULER.SET_JOB_ARGUMENT_VALUE ( job_name => 'backup_job', argument_position => 1, argument_value => 'SCHEMA'); DBMS_SCHEDULER.SET_JOB_ARGUMENT_VALUE ( job_name => 'backup_job', argument_position => 2, argument_value => 'backup_dir'); DBMS_SCHEDULER.SET_JOB_ARGUMENT_VALUE ( job_name => 'backup_job', argument_position => 3, argument_value => 'FULL'); END; / ``` 其,repeat_interval 参数指定了备份的频率,这里设置为每天晚上 11 点。job_type 参数指定了备份类型,这里设置为 EXPORT,job_action 参数指定了备份的具体操作,这里设置为 SCHEMA_EXPORT,argument_position 参数指定了备份过程需要的参数,这里设置为 SCHEMA、backup_dir 和 FULL。 3. 运行备份作业: ``` BEGIN DBMS_SCHEDULER.RUN_JOB('backup_job', FALSE); END; / ``` 这将立即运行备份作业。您也可以等待计划的时间自动运行备份作业。 注意:在执行备份操作之前,请确保您有足够的磁盘空间来存储备份文件。此外,备份数据时可能会影响数据库性能,请在高峰期之外执行备份操作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值