如何彻底删除Oracle数据库,以创建相同实例名称的库

简介: 今天建库时选择了OMF方式,结果文件名称采用Oracle自动命名的方式,看不懂啊,于是乎决定删除再重建。Oracle提供了删除数据库的指令:drop database。

今天建库时选择了OMF方式,结果文件名称采用Oracle自动命名的方式,看不懂啊,于是乎决定删除再重建。

Oracle提供了删除数据库的指令:drop database
需要数据库处于mount状态,然后alter system enable restricted session;,网上有帖子说还需要exclusive,由于我是VM装的,用户只有我一个,所以不用可以。由于当前处于open状态,需要改为mount,执行:
SQL> alter database close;
alter database close
*
ERROR at line 1:
ORA-01093: ALTER DATABASE CLOSE only permitted with no sessions connected
原因是有个session仍连接,退出后再次执行,
SQL> alter database close;
Database altered.

SQL> select status from v$instance;
STATUS
------------
MOUNTED

SQL> alter system enable restricted session;
System altered.

SQL> select status from v$instance;
STATUS
------------
MOUNTED

SQL> drop database;
Database dropped.

此时alert.log记录信息:
Create Relation ADR_CONTROL
Create Relation ADR_INVALIDATION
Create Relation INC_METER_IMPT_DEF
Create Relation INC_METER_PK_IMPTS
USER (ospid: 8748): terminating the instance
Instance terminated by USER, pid = 8748
Deleted Oracle managed file /opt/app/ora11g/oradata/BISAL/controlfile/o1_mf_9x4fgq77_.ctl
Deleted Oracle managed file /opt/app/ora11g/flash_recovery_area/BISAL/controlfile/o1_mf_9x4fgypb_.ctl
Completed: drop database
Shutting down instance (abort)
License high water mark = 2
Fri Jul 25 19:09:26 2014
Instance shutdown complete

到oradata路径下看已经没有任何文件了,那么认为这个数据库已经被删除。
但再次执行dbca,企图创建相同实例的库时报错:


虽然和bisal实例关联的数据文件、日志文件等已经物理删除了,但和这实例相关的配置文件没有删除,因此不能再次创建相同实例的库。

此时需要手工删除实例相关的配置
1、删除$ORACLE_BASE/admin/$ORACLE_SID所有目录。
2、删除$ORACLE_HOME/dbs下和SID相关的文件和参数文件,包括hc_bisal.dat,init.ora,lkBISAL,orapwbisal。
3、删除/etc/oratab中和实例相关的部分。
4、可以在$ORACLE_HOME中执行find . -name bisal,删除所有和实例相关的文件。

再次执行dbca,就可以创建相同实例名称的数据库了。

目录
相关文章
|
10月前
|
数据库
【数据库新建的表如何查看以及保存】
【数据库新建的表如何查看以及保存】
93 0
【数据库新建的表如何查看以及保存】
|
10月前
|
SQL 安全 数据库
【数据库】sql2008卸载和默认实例的删除
【数据库】sql2008卸载和默认实例的删除
529 0
|
SQL Oracle 关系型数据库
Oracle各种版本下“示例数据库的创建”的创建
Oracle各种版本下“示例数据库的创建”的创建
454 0
|
存储 NoSQL Linux
数据库的创建和删除 | 学习笔记
快速学习 数据库的创建和删除
67 0
数据库的创建和删除 | 学习笔记
|
SQL 数据库 数据库管理
数据库——数据库创建(模板与导入)
数据库——数据库创建(模板与导入)
数据库——数据库创建(模板与导入)
|
存储 Oracle 关系型数据库
Oracle 全局数据库名 数据库实例名 数据库服务名
本文目录 1. 简介 2. 比喻 3. 真实面目
292 0
|
SQL 数据库 Go
SQL脚本修改数据库名称
USE master; GO DECLARE @SQL VARCHAR(MAX); SET @SQL='' SELECT @SQL=@SQL+'; KILL '+RTRIM(SPID) FROM master.
936 0
|
SQL Oracle 关系型数据库

热门文章

最新文章

推荐镜像

更多