手動刪除oracle資料庫
分享一下我老師大神的人工智慧教程!零基礎,通俗易懂!http://blog.csdn.net/jiangjunshow
也歡迎大家轉載本篇文章。分享知識,造福人民,實現我們中華民族偉大復興!
--=====================
-- 手動刪除oracle數據庫
--=====================
的具體步驟,包含檔案系統數據庫以及ASM數據庫。環境:Oracle Enterprise Linux 5.4 + Oracle 10g R2 .
一、手動刪除檔案系統數據庫
1.停止監聽與OEM
$ lsnrctl stop listener_name
2.獲得數據檔案,日誌檔案及控制檔案的相關資訊,包含歸檔
$ sqlplus / as sysdba
SQL> select status,name
SQL> select * from v$dbfile; --獲取數據檔案的位置資訊
SQL> select * from v$logfile; --獲取日誌檔案的位置資訊
SQL> archive log list; --查看歸檔的sequence及位置資訊
SQL> shutdown abort; --因數據不再需要,直接shutdown abort
3.啟動到 mount 狀態(使用exclusive restart)
SQL> startup mount exclusive restrict;
4.修改引數為允許受限的會話模式
SQL> alter system enable restricted session;
5.使用drop database命令來清除數據庫
SQL> drop database;
SQL> exit
6.手動清除相關檔案
$ echo $ORACLE_SID --確認當前的ORACLE_SID
$ rm -rf $ORACLE_BASE/admin/$ORACLE_SID --刪除oracle base目錄下的$ORACLE_SID的所有內容
$ rm -rf $ORACLE_BASE/oradata/$ORACLE_SID --oradata下的數據檔案,根據前面的查詢,注意要刪除不同路徑下的數據檔案
$ rm -rf $ORACLE_BASE/arch/$ORACLE_SID --清除歸檔日誌,注意歸檔路徑的正確性
$ rm -rf $ORACLE_BASE/flash_recovery_area/$ORACLE_SID --清除閃回區的內容
$ rm -rf $ORACLE_HOME/dbs/*$ORACLE_SID* --清除引數檔案 */
7.清除監聽相關檔案(建議)
$ rm $TNS_ADMIN/*.ora --如果設定了$TNS_ADMIN變量,否則刪除默認路徑下的監聽檔案 */
$ rm $ORACLE_HOME/network/admin/*.ora */
8.修改oratab檔案以及.bash_profile
$ vi /etc/oratab --去掉實例相關的設置
$ vi ~/.bash_profile --去掉實例相關的設置
二、清除ASM數據庫
對於ASM數據庫的刪除與檔案系統數據庫的不同之處在於數據檔案,控制檔案,日誌檔案,引數檔案等都是存放在ASM系統中,因此需要在ASM實例中做相應
的動作來徹底清除數據庫。
1.執行檔案系統數據庫清除步驟3-4步(先要shutdown)
2.使用drop database命令來清除數據庫(該命令將清除數據檔案,日誌檔案,temp檔案)
SQL> drop database;
SQL> exit
3.連接到ASM實例
$ export ORACLE_SID=+ASM
$ sqlplus / as sysdba
4.清除殘余文件
SQL> select name,file_number,group_number,file_incarnation from v$asm_alias; --查看檔案,注意group_number表示位於不同的磁盤組
SQL> alter diskgroup DG1 drop directory