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、执行查询结果,然后再进行备份即可实现空表备份导出
还没有评论,来说两句吧...