因控制文件中还有源库CDB及各PDBs的temp文件的信息,这里可以使用如下语句删除。否则后面NID更改数据库名会报错。在源库中执行如下语句,拷贝结果到目标库执行即可。
select 'alter database tempfile '''||name||''' drop ; ' from v$tempfile ;
[oracle@nkgttv2024rhl test12]$ sqlplus / as sysdba
SQL> shut immediate
SQL> startup mount
做动作时同样需要切换到各个PDB(container),否则会报错找不到这个文件:
SQL> ALTER SESSION SET CONTAINER = CDB$ROOT;
SQL> alter database tempfile '/data01/oracle12c/oradata/test12c/temp01.dbf' drop ;
SQL>ALTER SESSION SET CONTAINER = PLUGDB;
SQL> alter database tempfile '/data01/oracle12c/oradata/test12c/plugdb/temp01.dbf' drop ;
....
修改数据库sid:
数据库启动到mount状态,然后在操作系统层执行命令:
[oracle@nkgttv2024rhl trace]$ nid target=/ dbname=test12
DBNEWID: Release 12.1.0.1.0 - Production on Thu Mar 6 15:50:31 2014
.....
Succesfully changed database name and ID.
DBNEWID - Completed succesfully.
NID 后注意环境变量修改。
A. 修改参数文件,将数据库名称相关的参数做修改(一般修改db_name, instance_name即可) 。
B. 在启动前生成一个新的password文件 :orapwd file=orapwtest12 password=Huaiwe123 entries=10
C. 注意环境变量,开启DB为mount , 使用 resetlogs 开启数据库: alter database open resetlogs ;
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/35489/viewspace-1103173/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/35489/viewspace-1103173/
本文介绍如何在Oracle数据库中安全地删除临时文件(tempfile),避免更改数据库SID时出现错误。此外,还提供了从mount状态更改数据库SID的具体步骤,包括必要的环境变量调整、参数文件更新以及新的密码文件生成。
2万+

被折叠的 条评论
为什么被折叠?



