【代码片】Shell定时导出备份Oracle数据库表

数据库表的备份有很多种,包括物理备份和逻辑备份,当然简单的方法是,直接在数据库中定时创建备份表进行备份。

这里分享个在主机上自动备份的SHELL脚本:

#!/usr/bin/bash
source /int_file/.bash_profile
function crontab_backup()
{
  crontab -l > /int_file/lubinsu/backup/crontab_bak/crontab_`date +%Y%m%d`.bak
  if [ $? = 0 ] 
  then
    find /int_file/lubinsu/backup/crontab_bak -name "crontab_*.bak" -type f -mtime +5 -exec rm {} \;
    return 0
  else
    return 1
  fi
}
function table_backup()
{
  expdp css/XXX#@css DIRECTORY=CSS_DUMP dumpfile=$1_`date +%Y%m%d`.dmp TABLES=$1
  if [ $? = 0 ] 
  then
    find /int_file/lubinsu/backup -name "$1_*.dmp" -type f -mtime +5 -exec rm {} \;
    return 0
  else 
    return 1
  fi
}
crontab_backup
value=`sqlplus -S css/XXX#@CSS << EOF
set heading off feedback off pagesize 0 verify off echo off
select table_name from tab_for_backup;
exit
EOF`
for loop in ${value}
do
  table_backup ${loop}
  if [ $? = 0 ]
  then
    :
  else
    echo "fail"
    exit 1
  fi
done

然后在crontab上加个定时即可:

#Backup crontab and tables daily
20 17 * * * /int_file/lubinsu/scripts/backup.sh >> /int_file/lubinsu/logs/`date +%Y%m%d`/backup.log

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值