资源预览内容
第1页 / 共4页
第2页 / 共4页
第3页 / 共4页
第4页 / 共4页
亲,该文档总共4页全部预览完了,如果喜欢就下载吧!
资源描述
由于数据库原始安装的原因造成数据库或整个操作系统的不安全或者由于磁盘空间变化再或者由于业务变化造成的I/O性能需要调整等等原因需要数据库管理员进行数据库文件位置的调整.下面通过一个WINDOWS平台的ORACLE数据文件移动为例子讨论一下数据库文件移动的方法,请大家指正.一.移动数据文件移动数据文件笔者目前使用的有2种办法,权作抛砖引玉.方法一、以数据文件为单位移动1.查看数据文件路径SQL select name from v$datafile;NAME-E:ORACLEORADATASLUMGABAKSYSTEM01.DBFE:ORACLEORADATASLUMGABAKUNDOTBS01.DBFE:ORACLEORADATASLUMGACWMLITE01.DBFE:ORACLEORADATASLUMGADRSYS01.DBFE:ORACLEORADATASLUMGAEXAMPLE01.DBFE:ORACLEORADATASLUMGAINDX01.DBFE:ORACLEORADATASLUMGAODM01.DBFE:ORACLEORADATASLUMGATOOLS01.DBFE:ORACLEORADATASLUMGAUSERS01.DBFE:ORACLEORADATASLUMGAXDB01.DBF2.关闭数据库SQL shutdown immediateDatabase closed.Database dismounted.ORACLE instance shut down.3.MOUNT到数据库SQL startup mountORACLE instance started.Total System Global Area135338868 bytesFixed Size453492 bytesVariable Size109051904 bytesDatabase Buffers25165824 bytesRedo Buffers667648 bytesDatabase mounted.4.把要移动的数据文件剪切到目标目录,这里的要移动SYSTEM数据文件从E:oracleoradataslumgabak到E:oracleoradataslumga4.alter database方法移动数据文件SQL alter database rename file E:ORACLEORADATASLUMGABAKSYSTEM01.DBF to E:ORACLEORADATASLUMGASYSTEM01.DBF;Database altered.5.移动其他数据文件同上.但是我们要注意的是TEMP数据文件.在我们上边列出数据文件的命令里没有包含这个文件.而且我们在SQL alter database rename file E:ORACLEORADATASLUMGAtemp01.DBF to E:ORACLEORADATASLUMGAbaktemp01.DBF;alter database rename file E:ORACLEORADATASLUMGAtemp01.DBF to E:ORACLEORADATASLUMGAbaktemp01.DBF*ERROR at line 1:ORA-01511: error in renaming log/data filesORA-01516: nonexistent log file, datafile, or tempfileE:ORACLEORADATASLUMGAtemp01.DBFSQL alter database rename tempfile E:oracleoradataslumgatemp01.dbf to E:oracleoradataslumgabaktemp01.dbf;alter database rename tempfile E:oracleoradataslumgatemp01.dbf to E:oracleoradataslumgabaktemp01.dbf*ERROR at line 1:ORA-02231: missing or invalid option to ALTER DATABASE是不可行的.具体关于TEMP数据文件我们会在下边讨论.6.移动完以后启动数据库SQL alter database open;SQL select name,status from v$datafile;方法二、以表空间为单位进行移动1.把相应表空间offlineSQL alter tablespace example offline;Tablespace altered.2.操作系统级把数据文件移动到目标目录3.在ORACLE数据库中把该表空间的所有数据文件改名SQL alter tablespace example rename datafile E:ORACLEORADATASLUMGABAKexample01.DBF to E:ORACLEORADATASLUMGAexample01.DBF;Tablespace altered.4.把表空间ONLINESQL alter tablespace example online;Tablespace altered.5.此方法对系统表空间system、undo表空间和temp表空间无法使用。SQL alter tablespace UNDOTBS1 offline;alter tablespace UNDOTBS1 offline*ERROR at line 1:ORA-30042: Cannot offline the undo tablespaceSQL alter tablespace system offline;alter tablespace system offline*ERROR at line 1:ORA-01541: system tablespace cannot be brought offline; shut down if necessarySQL alter tablespace temp offline;alter tablespace temp offline*ERROR at line 1:ORA-03217: invalid option for alter of TEMPORARY TABLESPACE如要修改temp表空间的位置,可以选择重新建立一个新的temp表空间,然后把新的表空间设置成默认的临时表空间,然后把老的DROP掉。详细语句SQL create temporary tablespace temp2 tempfile e:oracletem2.dbf size 20M reuseautoextend on next 50m maxsize unlimited;关闭数据库。mount到数据库。SQL alter database default temporary tablespace temp2;打开数据库二、移动控制文件1.用SPFILE启动的数据库SQL alter system set control_files=E:oracleoradataslumgabakCONTROL01.CTL,E:oracleoradataslumgabakCONTROL02.CTL,E:oracleoradataslumgabakCONTROL03.CTL scope=spfile;System altered.重启数据库。SQL create pfile from spfile;File created.2.用pfile启动的数据库修改E:oracleora92databaseinit.ora 文件,修改参数CONTROL_FILES的值。重新启动数据库。如果有SPFIL重建SPFILESQL create spfile from pfile;三、移动联机重作日志文件。1.停止数据库2.把日志文件移动到新的目标目录3.mount到数据库,修改日志文件的名字SQL alter database rename file E:oracleoradataslumgaREDO01.LOG to E:oracleoradataslumgabakREDO01.LOG;Database altered.SQL alter database rename file E:oracleoradataslumgaREDO02.LOG to E:oracleoradataslumgabakREDO02.LOG;Database altered.SQL alter database rename file E:oracleoradataslumgaREDO03.LOG to E:oracleoradataslumgabakREDO03.LOG;Database altered.4.OPEN数据库SQL alter database open;修改完成!
收藏 下载该资源
网站客服QQ:2055934822
金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号