比较简单windows系统不用RMAN的oracle数据库热备脚本

现在的ORACLE一般都采用RMAN进行备份,不过在8及以前一般都是DBA自己写的一些备份脚本。
这是一个比较简单的windows系统不用RMAN的oracle数据库热备脚本。仅供参考学习用。
本代码包括以下两个文件。
主文件backup.bat,用来执行备份的批处理文件,配置好参数,直接运行即可。
rem 作者:叶正盛(MKing),2008-06-25

rem 设置ORACLE_SID

set ORACLE_SID=testdb

rem 设置备份目录

set backup_dest_path=H:/oracle/oradata/testdbbackup/

rem 设置归档日志目录

set archive_dest_path=H:/oracle/oradata/testdb/archive/

rem 创建备份的SQLPLUS脚本到mybackup.sql文件

sqlplus /nolog @createscript.sql

rem 执行备份

sqlplus /nolog @mybackup.sql %backup_dest_path% %archive_dest_path%
生成备份脚本文件createscript.sql 
connect / as SYSDBA

--关闭屏幕输出

set term off;

--关闭输出列头信息

set heading off;

--设置行长度

set linesize 500;

--关闭输出统计行数信息

set feedback off;

--关闭变量扫描

SET SCAN off;

--打开输出

SET SERVEROUTPUT ON SIZE 100000;

spool off 

--将生成的脚本输出到mybackup.sql文件

spool mybackup.sql

declare

  --读取数据表空间

  cursor cur_tbs is

    select distinct b.*

      from v$datafile a, v$tablespace b

     where a.TS# = b.TS#;

  --读取表空间数据文件

  cursor cur_datafile(iTS integer) is

    select * from v$datafile a where a.TS# = iTS;

  --读取控制文件

  cursor cur_controlfile is

  select * from v$controlfile;

  --读取重做日志文件

  cursor cur_redofile is

  select * from v$logfile;

begin

  --输出连接数据库命令

  dbms_output.put_line('connect / as SYSDBA;');

  for rec_tbs in cur_tbs loop

    --输出开始备份表空间命令

    dbms_output.put_line('alter tablespace ' || rec_tbs.name ||' begin backup;');

    for rec_datafile in cur_datafile(rec_tbs.ts#) loop

      --输出操作系统复制数据文件命令

      dbms_output.put_line('host copy /Y "'||rec_datafile.name||'" "&1";');

    end loop;

    --输出结束备份表空间命令

    dbms_output.put_line('alter tablespace ' || rec_tbs.name || ' end backup;');

  end loop;

  for rec_controlfile in cur_controlfile loop

    --输出操作系统复制控制文件命令

    dbms_output.put_line('host copy /Y  "'||rec_controlfile.name||'" "&1";');

  end loop;

  --输出切换日志命令

  dbms_output.put_line('alter system archive log current;');

  --输出备份归档日志文件命令

  dbms_output.put_line('host move /Y "&2*.*" "&1";');

  for rec_redofile in cur_redofile loop

    --输出备份重做日志文件命令

    dbms_output.put_line('host copy /Y  "'||rec_redofile.member||'" "&1";');

  end loop;

  --输出退出sqlplus命令

  dbms_output.put_line('exit;');

end;

/

spool off 

exit;

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值