ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

Oracle工具之DBNEWID

2021-12-27 15:03:48  阅读:199  来源: 互联网

标签:DBNEWID name database DBID changed 修改 oracle Oracle 工具


概述

DBNEWID是Oracle提供的一个用于修改数据库DBID和DBNAME的工具。

在引进该工具之前,如果我们想修改数据库的数据库名,必须重建控制文件。但即便如此,也无法修改该数据库的DBID。众所周知,DBID是一个数据库的唯一标识符。RMAN就是根据数据库的DBID来区分不同数据库的。

DBNEWID可解决这种问题,它提供了以下三种选择:

1> 只修改DBID

2> 只修改DBNAME

3> 同时修改DBID和DBNAME

注意:当一个数据库的DBID被修改后,它以前的备份和归档日志将不可用。并且在重新打开数据库时,需加上RESETLOGS选项,该选项将重新创建在线日志,并将它们的序列号重置为1。建议,修改完数据库的DBID后,对该库进行全备。

如果只是修改数据库的DBNAME,则以前的备份和归档日志不受影响。但是必须修改参数文件的db_name,否则,在重新打开数据库过程中,将报以下错误:ORA-01103: database name 'ORCL' in control file is not 'SZ'。表明控制文件的DBNAME和参数文件中的不匹配,需修改参数文件。同时,也需修改密码文件。

DBNEWID的使用语法如下

nid TARGET = [username] / [password] [@service_name] [REVERT = { YES | NO } |DBNAME = new_db_name [SETNAME = { YES | NO }]] [LOGFILE = logfile [APPEND = { YES | NO }] [HELP = { YES | NO }]]

其中,

  • TARGET输入用户名和密码,注意,该用户必须具有sysdba的权限。譬如target=sys/oracle,当然,如果我们是在操作系统本地操作的话,可用反斜杠连接,即target=/

  • REVERT指明一个失败的DBID操作是否需要回退。默认是NO。注意,如果数据库的DBID修改成功,该操作无法回退。该回退操作只针对失败的DBID修改操作。

  • DBNAME指定新的数据库名。

  • SETNAME默认是NO,则该数据库将同时修改DBID和DBNAME。如果指定为YES,则该数据库将只修改DBNAME

  • LOGFILE日志文件,记录操作信息,默认是覆盖上个日志文件。如果APPEND设为YES的话,则这次操作信息将被追加到上个日志文件中。APPEND默认是NO。

  • HELP用来提示DBNEWID的语法规则。默认为NO

下面,我们将演示如何修改DBID和DBNAME

一、关闭数据库并重启到mount状态

SQL> shutdown immediate --必须是一致性关闭

SQL> startup mount

二、 修改DBID和DBNAME

[oracle@node3 ~]$ nid target=sys/oracle dbname=victor --原来的dbname是orcl。

我们来看看输出

DBNEWID: Release 11.2.0.1.0 - Production on Thu Sep 25 05:00:34 2014

Copyright (c) 1982, 2009, Oracle and/or its affiliates. All rights reserved.

Connected to database ORCL (DBID=1386938297)

Connected to server version 11.2.0

Control Files in database:
  /u01/app/oracle/oradata/sz/control01.ctl
  /u01/app/oracle/flash_recovery_area/sz/control02.ctl

Change database ID and database name ORCL to VICTOR? (Y/[N]) => y

Proceeding with operation
Changing database ID from 1386938297 to 431720306
Changing database name from ORCL to VICTOR
  Control File /u01/app/oracle/oradata/sz/control01.ctl - modified
  Control File /u01/app/oracle/flash_recovery_area/sz/control02.ctl - modified
  Datafile /u01/app/oracle/oradata/sz/system01.db - dbid changed, wrote new name
  Datafile /u01/app/oracle/oradata/sz/sysaux01.db - dbid changed, wrote new name
  Datafile /u01/app/oracle/oradata/sz/undotbs01.db - dbid changed, wrote new name
  Datafile /u01/app/oracle/oradata/sz/users01.db - dbid changed, wrote new name
  Datafile /u01/app/oracle/oradata/sz/temp01.db - dbid changed, wrote new name
  Control File /u01/app/oracle/oradata/sz/control01.ctl - dbid changed, wrote new name
  Control File /u01/app/oracle/flash_recovery_area/sz/control02.ctl - dbid changed, wrote new name
  Instance shut down

Database name changed to VICTOR.
Modify parameter file and generate a new password file before restarting.
Database ID for database VICTOR changed to 431720306.
All previous backups and archived redo logs for this database are unusable.
Database is not aware of previous backups and archived logs in Recovery Area.
Database has been shutdown, open database with RESETLOGS option.
Succesfully changed database name and ID.
DBNEWID - Completed succesfully.

 

输出最后提示修改成功。

注意:在发出nid命令后,DBNEWID首先会校验数据文件、控制文件的有效性。如果校验通过,则DBNEWID会提示是否继续执行该操作,如上面输出中的Change database ID and database name ORCL to VICTOR? (Y/[N])。如果指明了日志文件,则不会有此提示。接着,DBNEWID会修改每个数据文件的DBID,包括离线数据文件和只读数据文件。接着关闭数据库,然后退出。

在10.1及以后版本中,该操作也会记录在告警日志中。如

*** DBNEWID utility started ***
DBID will be changed from 1386938297 to new DBID of 431720306 for database ORCL
DBNAME will be changed from ORCL to new DBNAME of VICTOR
Starting datafile conversion
Datafile conversion complete
Database name changed to VICTOR.
Modify parameter file and generate a new password file before restarting.
Database ID for database VICTOR changed to 431720306.
All previous backups and archived redo logs for this database are unusable.
Database has been shutdown, open with RESETLOGS option.
Succesfully changed database name and ID.
*** DBNEWID utility finished succesfully ***

 

三、 修改参数文件

SQL> create pfile='/home/oracle/victor.pfile' from spfile;

[oracle@node3 trace]$ vim /home/oracle/victor.pfile

db_name='orcl' 修改为 db_name='victor'

四、重新启动数据库

SQL> create spfile from pfile='/home/oracle/victor.pfile';

SQL> startup mount

SQL> alter database open resetlogs;

SQL> show parameter name

NAME TYPE VALUE ------------------------------------ ----------- ------------------------------ db_file_name_convert string db_name string victor db_unique_name string victor global_names boolean FALSE instance_name string orcl lock_name_space string log_file_name_convert string service_names string victor

可见,dbname修改成功。当然,实例名依旧是原来的orcl。

如果需要将实例名修改为victor,命令如下:

SQL> alter system set instance_name='victor' scope=spfile;

总结:该范例示范的是同时修改DBID和DBNAME。

1> 如果只是修改DBID,则上述第二步命令不用指定dbname参数,即$ nid target=sys/oracle即可。但重新开启数据库时,同样需要指定RESETLOGS子句。

2> 如何只是修改DBNAME,则上述第二步命令中需将setname指定为YES,即$ nid target=sys/oracle dbname=victor setname=yes。直接startup开库,不需指定RESETLOGS子句。

3> DBNEWID不会修改global database name。可通过以下命令修改:

SQL> alter database rename global_name to victor.being.com。其中being.com为域名。

官方文档:http://docs.oracle.com/cd/E11882_01/server.112/e22490/dbnewid.htm#SUTIL014

标签:DBNEWID,name,database,DBID,changed,修改,oracle,Oracle,工具
来源: https://www.cnblogs.com/lkj371/p/15736247.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有