方法一
1、备份数据库(X:\oracle\oradata)下的数据文件,重新命名即可(否则装数据库的时候会提示SID已存在)。重新安装数据库,当然数据库的名字就是你要恢复的名字。安装完成后,打开Services.msc,停止oracle的服务2个。
2、把(X:\oracle\oradata)下新出现的文件改名,把原先目录下的文件恢复本来面目,再重新启动oracle服务和监听。用sys/as dba 登陆数据库,可能会提示权限不够(ora-01031)修改(X:\oracle\ora92\network\admin )文件夹下的sqlnet.ora文件,添加SQLNET.AUTHENTICATION_SERVICES= (NTS),这样能增加权限。
3、登陆进去后,打开table提示不能打开。打开common页,执行命令alert database open;
这时再刷新table,发现原先的表可以打开了。
方法二
1、将原来的ORACLE文件夹改名,原来的路径是D:\oracle。我暂时改成D:\oracle_old。找来ORACLE(我用的是ORACLE 9I)安装光盘,将ORACLE安装在原来安装的目录下,这样恢复起来更加方便,主要是注册表的内容不用修改。
2、安装完了之后,系统中又有一个可以使用的ORACLE了。这个时候要做的就是将原来的文件和数据恢复过来。第一步,先关闭ORACLE的所有已经启动的项目,在“服务”里面逐一关闭。然后,将安装目录改名。我现在用的是D:\oracle。改成D:\oracle_new。再将D:\oracle_old改成D:\oracle。 很多人可能以为这样就行了,文件都在了,环境都一样了,其实还不够
3、命令行下运行:oradim -delete -sid instOracle 来删除SID,其中instOracle为创建oracle时候创建的实例 强烈推荐执行这个命令后重新启动机器,重启后就可以建立和原来实例名相同的实例。不重新启动也可以,但是你的实例名就不能和原来的一样了。
4、在dos环境下执行命令 oradim -new -sid mm -startmode a -pfile "D:\oracle\admin\mm\pfile\initmm.ora "创建一个新的实例,其中 "mm"为新数据库的名称。
5、启动服务,先打开数据库,然后可以用以前的用户名和密码登陆进去。 要补充的是,一般的ORACLE数据库的监听程序都是用电脑的名称来识别地址的,而不是127.0.0.1或者localhost。所以,如果我们安装系统的时候用的是不同的电脑名称(比如我原来用的是biweilun。重新安装后用的是tr0j4n),那么我们还有一个工作要做,就是修改文件 listener.ora。将里面的相关的东西改过来就可以了。其实恢复的精髓就是,保证环境要一模一样。注:恢复必须要有以下文件
A)初始化参数文件INIT.ORA
B)所有数据文件 .dbf
C)所有重做(redo)日志文件(联机日志、归档日志)
D)所有控制文件 .crtl
E)internal密码文件