程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle教程 >> 實戰:oracle刪除表空間的shell腳本

實戰:oracle刪除表空間的shell腳本

編輯:Oracle教程

實戰:oracle刪除表空間的shell腳本


#!/bin/bash
#[email protected]
#drop tablespace

if [ $# -ne 1 ]; then
echo "Usage: $0 TABLESPACE_NAME "
exit 1
fi

#configure oracle env:about oracle envs, username and password

ORACLE_SID=orcl

ORACLE_HOME=/u01/app/oracle/product/11.2.0/db_1

ora_data=/u01/app/oracle/product/11.2.0/db_1/dbs/

ora_user="sys" #oracle username

ora_pass="password" #oracle user password

tablespace_name=$(echo $1 | tr '[a-z]' '[A-Z]')

outfiletmp=/tmp/droptpstmp01.txt #specify the output file location

sqlplus -S "${ora_user}/${ora_pass} as sysdba" <<!01 >/dev/null #禁止sqlplus執行結果回顯
set heading off;
set feedback off;
set termout off;
set pagesize 0;
set verify off;
set echo off;
spool ${outfiletmp}
select tablespace_name from dba_tablespaces where tablespace_name='${tablespace_name}';
spool off
exit;
!01

tps_jug=`grep -i ${tablespace_name} ${outfiletmp} `

if [ "${tps_jug}" = "${tablespace_name}" ]; then
wind_var=$(
sqlplus -s "{ora_user}/${ora_pass} as sysdba" <<EOF
set heading off
drop tablespace ${tablespace_name} including contents and datafiles;
EXIT;
EOF)
echo -e "\e[1;32m ${wind_var} \e[0m" #Direct display returns results
rm -rf ${outfiletmp}
exit 1
else
echo -e "\e[1;31m --------------------------------------- \e[0m"
echo -e "\e[1;31m The tablespace ${tablespace_name} not exits! \e[0m"
echo -e "\e[1;31m --------------------------------------- \e[0m"
rm -rf ${outfiletmp}
exit 1

fi

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved