今收到一个控制文件和一堆数据文件, 要在我的笔记本上打开这个库, 我是很不愿意用open resetlogs选项的, 因为控制文件和数据文件是一致的, 是在关闭数据库的情况下备份出来的. 结果发现日志文件原来是在E盘, 而我的笔记本上只有C盘, 直接Clear是不行的, 直接重命名也是不行的, 通过添加新日志组和删除旧日志组也不行, 因为其中有一组是当前Active的, 因此根本就不让删除.

SQL> SELECT MEMBER FROM V$LOGFILE;

MEMBER
---------------------------------------------
E:\ORACLE\PRODUCT\ORADATA\PROD\REDO01.LOG
E:\ORACLE\PRODUCT\ORADATA\PROD\REDO02.LOG
E:\ORACLE\PRODUCT\ORADATA\PROD\REDO03.LOG

    没办法了? 当然是有办法的了, 我们可以简单地骗过Oracle, 方法是我在C盘的相应目录中建了三个空文本文件, 大小全是0, 只是名字和日志文件的一样, 然后就启动到Mount方式, 进行重命名日志文件, 然后再清除每一个日志文件组, 最后就直接打开了数据库, 没有使用open resetlogs选项.

    本故事纯属虚构. 但这个方法是行得通的, 你可以试试.