博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
手动删除数据库 oracle
阅读量:7090 次
发布时间:2019-06-28

本文共 3120 字,大约阅读时间需要 10 分钟。

 

--=====================
-- 
动删
oracle
--=====================
 
    在很多情况下,或无法使用dbca工具的时候,我们需要手动来删除数据库。对此,可以借助drop database命令来实现,下面的描述中给出手动删除数据库
的具体步骤,包含文件系统数据库以及ASM数据库。环境:Oracle Enterprise Linux 5.4 +  Oracle 10g R2 .
 
一、手动删除文件系统数据库
 
    1.停止监听与OEM
        $ lsnrctl stop listener_name
        $ emctl stop dbconsole
       
    2.获得数据文件,日志文件及控制文件的相关信息,包含归档        
        $ sqlplus / as sysdba
        SQL> select status,name from v$controlfile;    
--
取控制文件的位置信息
        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 '+DG1/asmdb/file_name';               
--
可以使用方式
来删
除需要
除的文件
        SQL> alter diskgroup REV drop directory '+REV/asmdb/file_name';
        SQL> select name,file_number,group_number,file_incarnation from v$asm_alias;      
--
验证删
除后的
    
        也可以使用下面的方式 (asmcmd命令)来删除残余文件
        $ export ORACLE_SID=+ASM
        $ asmcmd
        ASMCMD> ls -l
        State    Type     Rebal Unbal Name
        MOUNTED EXTERN N      N      DG1/
        MOUNTED EXTERN N      N      REV/
        ASMCMD> ls -s
        Sector Block        AU Total_MB Free_MB Req_mir_free_MB Usable_file_MB Offline_disks Name
           512    4096 1048576       3067      2974                 0             2974               0 DG1/
           512    4096 1048576       2047      1996                 0             1996               0 REV/
        ASMCMD> cd +DG1
        ASMCMD> ls
        ASMDB/
        ASMCMD> rm -rf ASMDB
        ASMCMD> ls
        ASMCMD> cd +REV
        ASMCMD> pwd
        +REV
        ASMCMD> ls
        ASMCMD> cd +   
        ASMCMD> ls -s
        Sector Block        AU Total_MB Free_MB Req_mir_free_MB Usable_file_MB Offline_disks Name
           512    4096 1048576       3067      3016                 0             3016               0 DG1/
           512    4096 1048576       2047      1996                 0             1996               0 REV/
       
        对于直接位于磁盘组下的文件则同样可以使用rm命令来直接删除文件   
       
    5.清除其它文件
        尽管数据文件,归档日志,联机日志,临时文件,参数文件都存放在ASM磁盘中,但dump文件,告警日志依然位于磁盘,需要手动清除
        $ echo $ORACLE_SID    
--
认当
前的
ORACLE_SID
        $ rm -rf $ORACLE_BASE/admin/$ORACLE_SID          
--
oracle base
下的
$ORACLE_SID
的所有
        $ rm -rf $ORACLE_HOME/dbs
/*$ORACLE_SID*         --
参数
文件
          */
   
6.执行文件系统数据库清除步骤7-8步
本文转自东方之子736651CTO博客,原文链接: http://blog.51cto.com/ecloud/1143857,如需转载请自行联系原作者
你可能感兴趣的文章
Javascript获取元素的坐标
查看>>
使用 lsof 查找打开的文件
查看>>
Linkwedo 提升信息在决策中的力量
查看>>
雨林木风GhostXP_SP3装机版YN11.6_2011.06更新
查看>>
我的友情链接
查看>>
vim8.0 不能用鼠标
查看>>
OpenGL进阶(十) - obj文件的导入
查看>>
剑指XX游戏(八) - 腾讯2013校园招聘技术类笔试题详解
查看>>
docker 添加基础命令
查看>>
arm7上搭建boa并进行测试cgi+html
查看>>
iptables/netfiles基本使用
查看>>
angularJS拍照
查看>>
HTML5接入与OC交互
查看>>
错误整理:No plugin found for prefix 'jetty' in the....
查看>>
端口号简介
查看>>
JCreator中不能引入servlet包的解决办法
查看>>
mysql root账户被删除
查看>>
将CentOS设置为用光盘做yum源
查看>>
终于用上了比较完美的lion 10.7.3
查看>>
【CentOS 7笔记47】,rsync文件同步工具#171205
查看>>