RELATEED CONSULTING
相关咨询
选择下列产品马上在线沟通
服务时间:8:30-17:00
你可能遇到了下面的问题
关闭右侧工具栏

新闻中心

这里有您想知道的互联网营销解决方案
一个冷备份的自动执行脚本-创新互联

花了一天多时间,捣鼓出一个SQL 脚本,用于执行ORACLE自动冷备份。记录如下:

创新互联服务项目包括文登网站建设、文登网站制作、文登网页制作以及文登网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,文登网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到文登省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!set echo off                               --关闭命令回显,但会显示执行后的命令。 set serveroutput on                        --返回结果,如果关闭,将无法把结果传到下一个文件。 set escape on                              --打开转义符功能,否则遇到/无法进行。 set heading off                            --关闭结果标题行显示 set line 300                               --设置返回结果显示宽度,避免遇到结果跨行后sed命令取结果不完整。 ho mkdir $ORACLE_HOME/`date +%Y_%m_%d`     --创建存放备份文件的目录,以当天日期命名。要保证与下面SQL中目录一致。 spool  /tmp/bak1.sql declare                                    --声明一个变量。用于接收当前日期的值。 v_time varchar2(30); begin select to_char(sysdate,'yyyy_mm_dd') into v_time   --获取当天日期。 from dual; dbms_output.put_line('select ''ho cp ''\|\|name\|\|'' $ORACLE_HOME\/'||v_time||''' from v$controlfile;'); dbms_output.put_line('select ''ho cp ''\|\|name\|\|'' $ORACLE_HOME\/'||v_time||''' from v$datafile;'); dbms_output.put_line('select ''ho cp ''\|\|member\|\|'' $ORACLE_HOME\/'||v_time||''' from v$logfile;'); dbms_output.put_line('select ''ho cp ''\|\|name\|\|'' $ORACLE_HOME\/'||v_time||''' from v$tempfile;'); dbms_output.put_line('create pfile=''$ORACLE_HOME\/'||v_time||'\/init$ORACLE_SID.ora'' from spfile;'); dbms_output.put_line('ho cp $ORACLE_HOME\/dbs\/orapw$ORACLE_SID $ORACLE_HOME\/'||v_time); end; / spool off  --以上通过获取日期后,得到带有日期值的完整的SQL原始语句和一些结果说明语句。  --以下获取纯净的用来执行的原始SQL语句。 ho sed -n '/select/p' /tmp/bak1.sql >/tmp/bak2.sql ho sed -n '/^create/p' /tmp/bak1.sql >>/tmp/bak2.sql ho sed -n '/^ho cp/p;' /tmp/bak1.sql >>/tmp/bak2.sql --以下用来将原始SQL语句执行得到SQLPLUS语句,并备份了参数文件和密码文件,以及结果说明语句。 spool /tmp/bak3.sql start /tmp/bak2.sql spool off ho sed -n '/^ho cp/p' /tmp/bak3.sql >$ORACLE_HOME/back.sql     --过滤掉无用的结果说明语句。获取最终有用的SQLPLUS命令。 shutdown immediate                                             --关闭数据库进行冷备。 start $ORACLE_HOME/back.sql startup ho rm /tmp/bak*.sql $ORACLE_HOME/back.sql                      --删除临时生成的执行脚本。

说明:1.SQL下获取当前日期值,并应用到SQLPLUS命令的目录中是一个难点,折腾了一天。

         2.sed命令可以用sed -i来简化生成的过渡性sql脚本。

         3.应该可以在SQLPLUS下定义变量并赋予当天日期值,再运用到其他备份命令中,暂时没搞成功,回头有时间再研究。

         4.这是为了学习而搞得一个SQL脚本,或许用系统shell脚本来做,会更简洁有效。下一步再做一个系统shell脚本。

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


文章题目:一个冷备份的自动执行脚本-创新互联
链接分享:http://lswzjz.com/article/dcehis.html