文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

oracle 11g如何修改数据库名字和实例名字

2024-04-02 19:55

关注

这篇文章主要为大家展示了“oracle 11g如何修改数据库名字和实例名字”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“oracle 11g如何修改数据库名字和实例名字”这篇文章吧。

第一阶段:改sid

1、登录数据库查看先前的sid,总共三步,

[javascript] view plain copy print?

[oracle@localhost ~]$ sqlplus  /as sysdba 

SQL*Plus: Release 11.2.0.1.0 Production on Sat Oct 1 16:51:35 2011  

Copyright (c) 1982, 2009, Oracle.  All rights reserved.  

Connected to an idle instance  

SQL> startup  

ORACLE instance started.  

Total System Global Area  539848704 bytes  

Fixed Size                  1337748 bytes  

Variable Size             360711788 bytes  

Database Buffers          171966464 bytes  

Redo Buffers                5832704 bytes  

Database mounted.  

Database opened.  

SQL> select instance from v$thread ;  

INSTANCE  

--------------------------------------------------------------------------------  

orcl  

2、关闭数据库

[sql] view plain copy print?

SQL> shutdown immediate;  

Database closed.  

Database dismounted.  

ORACLE instance shut down.  

SQL> exit  

Disconnected from Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production  

With the Partitioning, OLAP, Data Mining and Real Application Testing options  

3、编辑/etc/oratab文件,把所有orcl换成test,大部分情况其实就一条。----这几步不需要管的。

[sql] view plain copy print?

[oracle@localhost ~]$ vim /etc/oratab   

4、更改oracle用户的 .bash_profile文件,把orcl改成test

[sql] view plain copy print?

[oracle@localhost ~]$ vim .bash_profile  

5、使改好的.bash_profile文件生效

[sql] view plain copy print?

[oracle@localhost ~]$ . .bash_profile  

7、查看系统环境变量

[sql] view plain copy print?

[oracle@localhost ~]$ env | grep ORACLE  

ORACLE_UNQNAME=test

ORACLE_SID=test

ORACLE_BASE=/u01/app/oracle  

ORACLE_HOME=/u01/app/oracle/product/11.2.0/dbhome_1  

效果已经生成。

8、进入$ORACLE_HOME/dbs查看目录,看那些有orcl,改成test

[sql] view plain copy print?

[oracle@localhost ~]$ cd $ORACLE_HOME/dbs  

[oracle@localhost dbs]$ ll  

总计 24  

-rw-rw---- 1 oracle oinstall 1544 10-01 16:55 hc_orcl.dat  

-rw-r--r-- 1 oracle oinstall 2851 2009-05-15 init.ora  

-rw-r----- 1 oracle oinstall   24 09-28 20:57 lkORCL  

-rw-r----- 1 oracle oinstall 1536 09-29 09:42 orapworcl  

drwx------ 2 oracle oinstall 4096 09-28 20:55 peshm_orcl_0  

-rw-r----- 1 oracle oinstall 2560 10-01 16:53 spfileorcl.ora  

9、更改文件名orcr>> test,ORCL>>test,命令如下:

[sql] view plain copy print?

[oracle@localhost dbs]$ mv hc_orcl.dat hc_test.dat   

[oracle@localhost dbs]$ mv orapworcl orapwtest  

[oracle@localhost dbs]$ mv lkORCL lkTEST 

[oracle@localhost dbs]$ mv peshm_orcl_0/ peshm_test_0/  

[oracle@localhost dbs]$ mv spfileorcl.ora spfiletest.ora   

10、重行生成密码文件,并查看

[sql] view plain copy print?

[oracle@localhost dbs]$ orapwd file=$ORACLE_HOME/dbs/orapw$ORACLE_SID password=sys entries=5 force=y  

[oracle@localhost dbs]$ ls -lrt orap*  

-rw-r----- 1 oracle oinstall 2048 10-01 17:02 orapwtest  

11、登录数据库,并查看实例名字,结果表明sid已由orcl变成test了  

[sql] view plain copy print?

[oracle@localhost dbs]$ sqlplus  / as sysdba  

SQL*Plus: Release 11.2.0.1.0 Production on Sat Oct 1 17:03:25 2011  

Copyright (c) 1982, 2009, Oracle.  All rights reserved.  

Connected to an idle instance.  

SQL> startup  

ORACLE instance started.  

Total System Global Area  539848704 bytes  

Fixed Size                  1337748 bytes  

Variable Size             327157356 bytes  

Database Buffers          205520896 bytes  

Redo Buffers                5832704 bytes  

Database mounted.  

Database opened.  

SQL> select instance from v$thread  

  2  ;  

INSTANCE  

--------------------------------------------------------------------------------  

test  

第二部分:不用退出登录,接着开始第二部分,更改数据库名dbname

2.1备份控制文件

[sql] view plain copy print?

SQL>  alter database backup controlfile to trace resetlogs;  

Database altered.  

2.2关闭并退出数据库

[sql] view plain copy print?

SQL> 

Database closed.  

Database dismounted.  

ORACLE instance shut down.  

SQL> exit  

Disconnected from Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production  

With the Partitioning, OLAP, Data Mining and Real Application Testing options  

2.3 orcale 11.2g的控制文件的备份目录为

/u01/app/oracle/diag/rdbms/ORCL/test/trace       ###告警日志里面 ,注意rdbms后面应该是ORCL,因为数据库名字还没有改变。

[sql] view plain copy print?

[oracle@localhost trace]$ ls -lrt  

总计 80  

-rw-r----- 1 oracle oinstall   256 10-01 17:03 test_ora_5286.trm  

-rw-r----- 1 oracle oinstall 14393 10-01 17:03 test_ora_5286.trc  

-rw-r----- 1 oracle oinstall    68 10-01 17:03 test_mman_5334.trm  

-rw-r----- 1 oracle oinstall   852 10-01 17:03 test_mman_5334.trc  

-rw-r----- 1 oracle oinstall    61 10-01 17:03 test_cjq0_5437.trm  

-rw-r----- 1 oracle oinstall   993 10-01 17:03 test_cjq0_5437.trc  

-rw-r----- 1 oracle oinstall    82 10-01 17:04 test_dbrm_5328.trm  

-rw-r----- 1 oracle oinstall  1172 10-01 17:04 test_dbrm_5328.trc  

-rw-r----- 1 oracle oinstall    90 10-01 17:05 test_vktm_5320.trm  

-rw-r----- 1 oracle oinstall  1233 10-01 17:05 test_vktm_5320.trc  

-rw-r----- 1 oracle oinstall    72 10-01 17:05 test_vkrm_5439.trm  

-rw-r----- 1 oracle oinstall   996 10-01 17:05 test_vkrm_5439.trc  

-rw-r----- 1 oracle oinstall   174 10-01 17:05 test_ora_5419.trm  

-rw-r----- 1 oracle oinstall  5894 10-01 17:05 test_ora_5419.trc  

-rw-r----- 1 oracle oinstall  5969 10-01 17:05 alert_test.log  

[oracle@localhost trace]$ vim alert_test.log   

[sql] view plain copy print?

可以在 alter_test.log里找到contolfile的备份trc,<em>sid_</em>ora_nnnn.trc 最新的一个就是。  

alter_test.log里面有这样一行字样,告诉你哪个是控制备份文件

[sql] view plain copy print?

Backup controlfile written to trace file /u01/app/oracle/diag/rdbms/orcl/test/trace/test_ora_5419.trc  

2.5复制一份

[sql] view plain copy print?

[oracle@localhost trace]$ cp test_ora_5419.trc  test.sql  

2.6编辑 test.sql,也就是test_ora_5419.trc的复制品。

1)查找STARTUP NOMOUNT语句,将这一行上面的所有行都删除

2)查找所有以--开始的行,把这些行删除

3)查找所有的orcl修改为test,所有的ORCL修改为test   ###这个步骤不做也可以,做的目的就是为了符合规矩,实际上控制文件数据文件的目录是可以随便起的。

4)找到CREATE CONTROLFILE REUSE DATABASE...语句,将其中的REUSE修改为SET

5)找到RECOVER DATABASE USING BACKUP CONTROLFILE语句,将其用双横线(--)注释掉

结果如下:

[sql] view plain copy print?

STARTUP NOMOUNT  

CREATE CONTROLFILE SET  DATABASE "test" RESETLOGS  NOARCHIVELOG  

    MAXLOGFILES 16  

    MAXLOGMEMBERS 3  

    MAXDATAFILES 100  

    MAXINSTANCES 8  

    MAXLOGHISTORY 292  

LOGFILE  

  GROUP 1 '/u01/app/oracle/oradata/test/redo01.log'  SIZE 50M BLOCKSIZE 512,  

  GROUP 2 '/u01/app/oracle/oradata/test/redo02.log'  SIZE 50M BLOCKSIZE 512,  

  GROUP 3 '/u01/app/oracle/oradata/test/redo03.log'  SIZE 50M BLOCKSIZE 512  

-- STANDBY LOGFILE  

DATAFILE  

  '/u01/app/oracle/oradata/test/system01.dbf',  

  '/u01/app/oracle/oradata/test/sysaux01.dbf',  

  '/u01/app/oracle/oradata/test/undotbs01.dbf',  

  '/u01/app/oracle/oradata/test/users01.dbf',  

  '/u01/app/oracle/oradata/test/example01.dbf'  

CHARACTER SET ZHS16GBK  

;  

--RECOVER DATABASE USING BACKUP CONTROLFILE  

ALTER DATABASE OPEN RESETLOGS;  

ALTER TABLESPACE TEMP ADD TEMPFILE '/u01/app/oracle/oradata/test/temp01.dbf'  

     SIZE 30408704  REUSE AUTOEXTEND ON NEXT 655360  MAXSIZE 32767M;  

2.7生成配置文件

[sql] view plain copy print?

[oracle@localhost trace]$ sqlplus  /as sysdba  

SQL*Plus: Release 11.2.0.1.0 Production on Sat Oct 1 17:12:48 2011  

Copyright (c) 1982, 2009, Oracle.  All rights reserved.  

Connected to an idle instance.  

SQL> create pfile   from spfile;  

File created.  

SQL> exit  

Disconnected  

2.8目录更改,这里和oracle 10g不一样,要注意。

[sql] view plain copy print?

[oracle@localhost ~]$ cd /u01/app/oracle/  

[oracle@localhost oracle]$ ls  

admin  cfgtoollogs  checkpoints  diag  flash_recovery_area  oradata  product  

[oracle@localhost oracle]$ cd flash_recovery_area/  

[oracle@localhost flash_recovery_area]$ ls  

orcl  ORCL  

[oracle@localhost flash_recovery_area]$ mv orcl/  test/  

[oracle@localhost flash_recovery_area]$ mv ORCL/  test/  

[oracle@localhost flash_recovery_area]$ cd ..  

[oracle@localhost oracle]$ ls  

admin  cfgtoollogs  checkpoints  diag  flash_recovery_area  oradata  product  

[oracle@localhost oracle]$ cd oradata/  

[oracle@localhost oradata]$ ls  

orcl  

[oracle@localhost oradata]$ mv orcl/ test/  

[oracle@localhost oradata]$ ls  

test  

[oracle@localhost oradata]$ cd ..  

[oracle@localhost oracle]$ ls  

admin  cfgtoollogs  checkpoints  diag  flash_recovery_area  oradata  product  

[oracle@localhost oracle]$ cd diag/  

[oracle@localhost diag]$ ls  

rdbms  tnslsnr  

[oracle@localhost diag]$ cd rdbms/  

[oracle@localhost rdbms]$ ls  

orcl  

[oracle@localhost rdbms]$ mv orcl/ test/  

[oracle@localhost rdbms]$ ls  

test  

[oracle@localhost rdbms]$ cd test  

[oracle@localhost test]$ ls  

i_1.mif  test  orcl  

[oracle@localhost test]$ cd ..  

[oracle@localhost rdbms]$ cd ..  

[oracle@localhost diag]$ ls  

rdbms  tnslsnr  

[oracle@localhost diag]$ cd ..  

[oracle@localhost oracle]$ cd admin/  

[oracle@localhost admin]$ ls  

orcl  

[oracle@localhost admin]$ cd orcl/  

[oracle@localhost orcl]$ ls  

adump  dpdump  pfile  

[oracle@localhost orcl]$ cd ..  

[oracle@localhost admin]$ mv orcl/  test/  

[oracle@localhost admin]$ ls  

test  

[oracle@localhost admin]$ sqlplus / as sysdba  

SQL*Plus: Release 11.2.0.1.0 Production on Sat Oct 1 17:18:02 2011  

Copyright (c) 1982, 2009, Oracle.  All rights reserved.  

Connected to an idle instance.  

SQL>                                                   

2.9删除的控制文件。

[sql] view plain copy print?

[oracle@localhost oradata]$ cd test/  

[oracle@localhost test]$ ls  

control01.ctl  redo01.log  redo03.log    system01.dbf  undotbs01.dbf  

example01.dbf  redo02.log  sysaux01.dbf  temp01.dbf    users01.dbf  

[oracle@localhost test]$ mv control01.ctl control01.ctl.aaa  

[oracle@localhost test]$ ls  

control01.ctl.aaa  redo01.log  redo03.log    system01.dbf  undotbs01.dbf  

example01.dbf      redo02.log  sysaux01.dbf  temp01.dbf    users01.dbf  

[oracle@localhost test]$ cd ..  

[oracle@localhost oradata]$ ls  

test  

[oracle@localhost oradata]$ cd..  

bash: cd..: command not found  

[oracle@localhost oradata]$ cd ..  

[oracle@localhost oracle]$ ls  

admin  cfgtoollogs  checkpoints  diag  flash_recovery_area  oradata  product  

[oracle@localhost oracle]$ cd flash_recovery_area/  

[oracle@localhost flash_recovery_area]$ ls  

test  test  

[oracle@localhost flash_recovery_area]$ cd test/  

[oracle@localhost test]$ ls  

control02.ctl  

[oracle@localhost test]$ mv control02.ctl control02.ctl.aaa  

2.10登录oracle生成spfile文件

[sql] view plain copy print?

[oracle@localhost test]$  sqlplus / as sysdba  

SQL*Plus: Release 11.2.0.1.0 Production on Sat Oct 1 17:23:34 2011  

Copyright (c) 1982, 2009, Oracle.  All rights reserved.  

Connected to an idle instance.  

SQL> create spfile from pfile='?/dbs/inittest.ora';  

File created.  

2.11调用前面步骤修改好的test.sql,目的是生成链接控制文件等

[sql] view plain copy print?

SQL> @/u01/app/oracle/diag/rdbms/test/test/trace/test.sql  

ORACLE instance started.  

Total System Global Area  539848704 bytes  

Fixed Size                  1337748 bytes  

Variable Size             327157356 bytes  

Database Buffers          205520896 bytes  

Redo Buffers                5832704 bytes  

Control file created.  

Database altered.  

Tablespace altered.  

2.12查看结果

[sql] view plain copy print?

SQL> select open_mode from v$database;  

OPEN_MODE  

--------------------  

READ WRITE  

SQL> show parameter name  

NAME                                 TYPE        VALUE  

------------------------------------ ----------- ------------------------------  

db_file_name_convert                 string  

db_name                              string      test  

db_unique_name                       string      test  

global_names                         boolean     FALSE  

instance_name                        string      test  

lock_name_space                      string  

log_file_name_convert                string  

service_names                        string      test.localdomain  

SQL> select name from v$database;  

NAME  

---------  

test  

SQL>   

上表明更改成功。

以上是“oracle 11g如何修改数据库名字和实例名字”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯