linux下的flashback脚本

一个客户比较关心逻辑错误的恢复,我们给他推荐的方案是在容灾库上使用flashback技术,下面是一个简单的linux的脚本。
#!/bin/bash

export LOGIN_USER=test
export LOGIN_PWD=test

#########################################function###############################################

flashscn()
{
echo -e "enter scn:\c"
read SCNNUM
STR1="flashback table $OWNER.$TABLE_NAME to scn $SCNNUM;"
echo $STR1
T1=`sqlplus -silent $LOGIN_USER/$LOGIN_USER <<EOF
set pagesize 0 feedback off verify off heading off echo off
alter table $OWNER.$TABLE_NAME enable row movement;
$STR1
alter table $OWNER.$TABLE_NAME disable row movement;
EOF`
if [ -z "$T1" ];then
echo "######"
echo "flashback table $TABLE_NAME OK!"
else 
echo "######"
echo "flashback tabel $TABLE_NAME error:"
echo $T1 |awk -F "ORA-" '{print "ORA-" $NF}' 
fi
}

flashtime()
{
echo -e "enter time (example 2014-05-18 20:34:21):\c"
read STIME
STR2="flashback table $OWNER.$TABLE_NAME to timestamp to_timestamp('$STIME','yyyy-mm-dd hh24:mi:ss');"
echo $STR2
T2=`sqlplus -silent $LOGIN_USER/$LOGIN_USER <<EOF
set pagesize 0 feedback off verify off heading off echo off
alter table $OWNER.$TABLE_NAME enable row movement;
$STR2
alter table $OWNER.$TABLE_NAME disable row movement;
EOF`
if [ -z "$T2" ];then
echo "######"
echo "flashback table $TABLE_NAME OK!"
else 
echo "######"
echo "flashback tabel $TABLE_NAME error:"
echo $T2 |awk -F "ORA-" '{print "ORA-" $NF}' 
fi

}

############################################main start##############################################

echo -e "enter flashback table owner:\c"
read OWNER
echo -e "enter flashbackup table name:\c"
read TABLE_NAME
echo -e "chose flashback type 1)time 2)scn  1\2 :\c"
read STYPE
case $STYPE in
    1)
flashtime
;;
    2)
flashscn
;;
    *)
echo "your enter is error,please enter 1 or 2 !!!"
exit
;;
esac

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值