【摘要】
創(chuàng)新互聯(lián)公司專(zhuān)注于成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站、成都外貿(mào)網(wǎng)站建設(shè)公司、網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站制作、網(wǎng)站開(kāi)發(fā)。公司秉持“客戶至上,用心服務(wù)”的宗旨,從客戶的利益和觀點(diǎn)出發(fā),讓客戶在網(wǎng)絡(luò)營(yíng)銷(xiāo)中找到自己的駐足之地。尊重和關(guān)懷每一位客戶,用嚴(yán)謹(jǐn)?shù)膽B(tài)度對(duì)待客戶,用專(zhuān)業(yè)的服務(wù)創(chuàng)造價(jià)值,成為客戶值得信賴的朋友,為客戶解除后顧之憂。
在12c版本之前,是不能夠在線重命名和移動(dòng)數(shù)據(jù)文件的。很多情況下,需要移動(dòng)數(shù)據(jù)文件或重命名,那么只能停機(jī)操作了。
但是到了12c,這個(gè)操作就變的非常簡(jiǎn)單了,可以在線操作,并且對(duì)應(yīng)用業(yè)務(wù)沒(méi)有任何影響,大大提高了數(shù)據(jù)庫(kù)的高可用性。其實(shí)12c很多新特性都是為了提高數(shù)據(jù)庫(kù)的高可用性而出來(lái)的,oracle對(duì)數(shù)據(jù)庫(kù)高可用性方面越來(lái)越重視。
下面介紹12c的在線重命名和移動(dòng)數(shù)據(jù)文件。
【正文】
首先,創(chuàng)建一個(gè)新的叫做TBS_FILE_TO_MOVE的表空間,該表空間只包含一個(gè)數(shù)據(jù)文件。
[oracle@Server ~]$sqlplus / as sysdba
SQL*Plus: Release12.1.0.1.0 Production on Fri Dec 20 03:03:50 2013
Copyright (c) 1982,2013, Oracle. All rights reserved.
Connected to:
Oracle Database 12cEnterprise Edition Release 12.1.0.1.0 - 64bit Production
With thePartitioning, OLAP, Advanced Analytics and Real Application Testing options
SQL> CREATESMALLFILE TABLESPACE TBS_FILE_TO_MOVE DATAFILE '/u01/app/oracle/oradata/NONCDB/file_to_move.dbf'
SIZE 100M AUTOEXTENDON NEXT 100M LOGGING DEFAULT NOCOMPRESS
ONLINE EXTENT MANAGEMENT LOCAL AUTOALLOCATE
SEGMENT SPACEMANAGEMENT AUTO
Tablespace created.
SQL> select name,status from v$datafile where name like '%file_to_move%'
NAME STATUS
---------------------------------------------------------
/u01/app/oracle/oradata/NONCDB/file_to_move.dbf ONLINE
SQL>!ls/u01/app/oracle/oradata/NONCDB/file_to_move*
/u01/app/oracle/oradata/NONCDB/file_to_move.dbf
對(duì)新創(chuàng)建的表空間TBS_FILE_TO_MOVE的數(shù)據(jù)文件"/u01/app/oracle/oradata/NONCDB/file_to_move.dbf"進(jìn)行了在線重命名:
SQL>alter databasemove datafile '/u01/app/oracle/oradata/NONCDB/file_to_move.dbf' to'/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf'
Database altered.
如果在此步驟中嘗試使用之前版本中提供的"alter database rename file"命令重命名數(shù)據(jù)文件的話,則會(huì)得到一個(gè)ORA-01121的錯(cuò)誤,提示指定的數(shù)據(jù)文件在使用或者回復(fù)的同時(shí)不能進(jìn)行重命名。
重命名操作完成之后,我們發(fā)現(xiàn)數(shù)據(jù)文件在控制文件和操作系統(tǒng)目錄中已經(jīng)顯示為新的名字(file_to_move2.dbf),并且其狀態(tài)仍然為ONLINE。
SQL>select name,status from v$datafile where name like '%file_to_move%'
NAME STATUS
---------------------------------------------------------
/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf ONLINE
SQL>!ls /u01/app/oracle/oradata/NONCDB/file_to_move*
/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf
使用帶有KEEP關(guān)鍵字的"alter database move datafile……"語(yǔ)句,將數(shù)據(jù)文件file_to_move.dbf重命名為file_to_move1.dbf(模擬數(shù)據(jù)文件在線移動(dòng))。如果在操作中指定了KEEP關(guān)鍵字,則會(huì)在原來(lái)的位置保留原來(lái)的數(shù)據(jù)文件,并同時(shí)會(huì)在新的位置創(chuàng)建一個(gè)新的數(shù)據(jù)文件的副本,在這種情況下,當(dāng)alter語(yǔ)句成功完成后,數(shù)據(jù)庫(kù)將僅使用新的數(shù)據(jù)文件而不會(huì)使用原有位置的舊的數(shù)據(jù)文件。因此,操作完成之后,在控制文件中將僅能看到新的file_to_move1.dbf數(shù)據(jù)文件,但在操作系統(tǒng)目錄中卻能同時(shí)看到舊的(file_to_move2.dbf)和新的數(shù)據(jù)文件(file_to_move1.dbf)。
SQL>alter databasemove datafile '/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf' to'/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf' KEEP
Database altered.
SQL>select name,status from v$datafile where name like '%file_to_move%'
NAME STATUS
---------------------------------------------------------
/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf ONLINE
SQL>!ls/u01/app/oracle/oradata/NONCDB/file_to_move*
/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf /u01/app/oracle/oradata/NONCDB/file_to_move2.dbf
在"alter databasemove datafile..."語(yǔ)句中同時(shí)指定了REUSE關(guān)鍵字,這是因?yàn)樵谖覀兩弦徊降闹孛僮髦?,我們?cè)?jīng)指定了KEEP關(guān)鍵字在原目錄位置保留了數(shù)據(jù)文件file_to_move2.dbf,如果我們此時(shí)不指定REUSE關(guān)鍵字,我們的操作就會(huì)因目標(biāo)數(shù)據(jù)件存在而報(bào)錯(cuò),如果指定了REUSE關(guān)鍵字,則將會(huì)直接覆蓋同名目標(biāo)數(shù)據(jù)文件。
SQL>alter databasemove datafile '/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf' to'/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf' REUSE
Database altered.
Data files from thecontrol file:
SQL>select name,status from v$datafile where name like '%file_to_move%'
NAME STATUS
---------------------------------------------------------
/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf ONLINE
Data files from theOperating System Directory
SQL>!ls/u01/app/oracle/oradata/NONCDB/file_to_move*
/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf
查詢到數(shù)據(jù)文件file_to_move2.dbf所對(duì)應(yīng)的數(shù)據(jù)文件號(hào)為100,接下來(lái),我們直接使用數(shù)據(jù)文件file_to_move2.dbf對(duì)應(yīng)的文件號(hào)(而不是具體指定其數(shù)據(jù)文件名稱(chēng)及位置)將其重命名為file_to_move1.dbf。
SQL>select name,status from v$datafile where name like '%file_to_move%'
NAME STATUS
---------------------------------------------------------
/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf ONLINE
Data files from theOperating System Directory
SQL>!ls/u01/app/oracle/oradata/NONCDB/file_to_move*
/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf
SQL>select file#from v$datafile where name = '/u01/app/oracle/oradata/NONCDB/file_to_move2.dbf'
FILE#
----------
100
SQL>alter databasemove datafile 100 to '/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf'
SQL>select name,status from v$datafile where name like '%file_to_move%'
NAME STATUS
---------------------------------------------------------
/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf ONLINE
SQL>!ls/u01/app/oracle/oradata/NONCDB/file_to_move*
/u01/app/oracle/oradata/NONCDB/file_to_move1.dbf
操作完成之后,通過(guò)v$datafile視圖,確認(rèn)控制文件中也已成功修改。
當(dāng)前文章:oracle12C新特性——之在線重命名和移動(dòng)數(shù)據(jù)文件
網(wǎng)站鏈接:http://muchs.cn/article34/ijoepe.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、服務(wù)器托管、移動(dòng)網(wǎng)站建設(shè)、定制網(wǎng)站、網(wǎng)站內(nèi)鏈、企業(yè)建站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)