Oracle工具之DBNEWID
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
Oracle工具之DBNEWID的更多相关文章
- 使用Navicat for Oracle工具连接oracle的图文教程
点评:今天上网的时候偶然发现了一款oracle的客户端的图形化管理和开发工具,当看到这个界面的时候,感觉很舒服,便上网搜了一下这个工具,看百度百科之后感觉很出乎我的意料,这个产品对于许多的数据库竟都有 ...
- [转]使用Navicat for Oracle工具连接oracle的
使用Navicat for Oracle工具连接oracle的 这是一款oracle的客户端的图形化管理和开发工具,对于许多的数据库都有支持.之前用过 Navicat for sqlserver,感觉 ...
- oracle删除dbf导致的oracle工具不能正常使用
1.使用cmd命令登录Oracle:sqlplus / as sysdba;就可以,中间两个空格.2.删除了dbf导致Oracle工具不能正常使用解决办法(oracle initialization ...
- 使用Navicat for Oracle工具连接oracle
使用Navicat for Oracle工具连接oracle的 这是一款oracle的客户端的图形化管理和开发工具,对于许多的数据库都有支持.之前用过 Navicat for sqlserver,感觉 ...
- 使用Navicat for Oracle工具连接oracle出错:ORA-12737
今天上网的时候偶然发现了一款oracle的客户端的图形化管理和开发工具,当看到这个界面的时候,感觉很舒服,便上网搜了一下这个工具,看百度百科之后感觉很出乎我的意料,这个产品对于许多的数据库竟都有支持, ...
- oracle工具 sqlplus 用户管理
可以通过system用户对普通用户解锁.alter user scott account unlock; 工具:1/ sqlplusw sqlplus 自带.调用oracle安装目录下bin目录下的e ...
- Oracle工具——ADRCI
ADRCI工具是Oracle11g才推出的新工具,主要用来管理alert文件.trace文件.dump文件.健康监事报告等. 这一篇简单介绍ADRCI工具. 用过11g的人都会发现,11g中alert ...
- JDBC连接Oracle工具类
import java.sql.*;import java.util.ResourceBundle; /** * jdbc工具类,负责: * 1. 加载/注册数据库驱动程序 * 2. 获取数据库连接 ...
- Oracle工具类-生成数据库现有Job的创建脚本
生成Oracle数据库现有Job的创建脚本 -- 生成现有Job的创建脚本 create or replace procedure proc_generate_job_create_sql is be ...
随机推荐
- Mac 识别NTFS移动硬盘
下载工具 TUXERA NTFS 2014
- Java-ios推送
之前做的消息推送,向Android和ios客户端推送.这里只说ios的推送,ios的推送最后都会推送到苹果的APNS服务器上,再有APNS服务器推送到ios设备上.因为考虑到这一点,第一版的消息推送苹 ...
- Atom.io设置ctrl+delete
一般常见的text editor,在文本前面的空白处按下ctrl+delete,只是删除空白符到单词前面停下,但是Atom.io的默认设置,把空白符后遇到的第一个单词也删掉了.改配置方法是在keyma ...
- SSIS内存不足
[SSIS.Pipeline] 信息: 缓冲区管理器检测到系统的虚拟内存不足,但无法换出任何缓冲区.考虑了 0 个缓冲区,锁定了 0 个缓冲区.或者是因未安装足够的内存或其他进程正在使用内存,以致于没 ...
- 更改apache网站根目录导致localhost不能访问
使用xampp或wamp安装完集成环境后,更改apache的网站根目录会导致localhost,localhost/phpmyadmin访问不到. 解决方法: 打开apache的配置文件:“../ap ...
- blogilo在chinaunix发布博客的设置
1. 在日志类型菜单中选择"Metaweblog API". 2. 在日志的远程发布url中输入"http://blog.chinaunix.net/xmlrpc.php ...
- 【转】各种语言中的urlencode方法
URLENCODE和URLDECODE是比较常用的URL参数转换方法,为以后使用方便,自己归类一下. 原文地址:http://blog.sina.com.cn/s/blog_3f195d25010 ...
- Xamarin跨平台移动开发解决方案
Xamarin始创于2011年,旨在使移动开发变得难以置信地迅捷和简单.Xamarin的产品简化了针对多种平台的应用开发,包括iOS.Android.Windows Phone和Mac App.Xam ...
- TableLayout表格布局详解
一.Tablelayout简介 Tablelayout类以行和列的形式对控件进行管理,每一行为一个TableRow对象,或一个View控件.当为TableRow对象时,可在TableRow下添加子控件 ...
- 建立自己的Visual Studio工程模板
如果你需要经常创建自己的特殊工程的话,那么预先建立自定义的工程模块,可能会让你的工作变得更轻松一些. 实现方法很简单,一共只需要六个步骤: 一. 新建工程 * 这里选用空白的Web工程. 二. 建立必 ...