溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

oracle12C 新特性——之在線重命名和移動數(shù)據(jù)文件

發(fā)布時(shí)間:2020-08-08 02:49:37 來源:網(wǎng)絡(luò) 閱讀:780 作者:嘉為 欄目:關(guān)系型數(shù)據(jù)庫

【摘要】

12c版本之前,是不能夠在線重命名和移動數(shù)據(jù)文件的。很多情況下,需要移動數(shù)據(jù)文件或重命名,那么只能停機(jī)操作了。

但是到了12c,這個(gè)操作就變的非常簡單了,可以在線操作,并且對應(yīng)用業(yè)務(wù)沒有任何影響,大大提高了數(shù)據(jù)庫的高可用性。其實(shí)12c很多新特性都是為了提高數(shù)據(jù)庫的高可用性而出來的,oracle對數(shù)據(jù)庫高可用性方面越來越重視。

下面介紹12c的在線重命名和移動數(shù)據(jù)文件。

【正文】

  在線重命名數(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

 

對新創(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ù)文件的話,則會得到一個(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)鍵字在線移動數(shù)據(jù)文件

 

使用帶有KEEP關(guān)鍵字的"alter database move datafile……"語句,將數(shù)據(jù)文件file_to_move.dbf重命名為file_to_move1.dbf(模擬數(shù)據(jù)文件在線移動)。如果在操作中指定了KEEP關(guān)鍵字,則會在原來的位置保留原來的數(shù)據(jù)文件,并同時(shí)會在新的位置創(chuàng)建一個(gè)新的數(shù)據(jù)文件的副本,在這種情況下,當(dāng)alter語句成功完成后,數(shù)據(jù)庫將僅使用新的數(shù)據(jù)文件而不會使用原有位置的舊的數(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

  使用REUSE關(guān)鍵字重命名一個(gè)在線數(shù)據(jù)文件

"alter databasemove datafile..."語句中同時(shí)指定了REUSE關(guān)鍵字,這是因?yàn)樵谖覀兩弦徊降闹孛僮髦?,我們曾?jīng)指定了KEEP關(guān)鍵字在原目錄位置保留了數(shù)據(jù)文件file_to_move2.dbf,如果我們此時(shí)不指定REUSE關(guān)鍵字,我們的操作就會因目標(biāo)數(shù)據(jù)件存在而報(bào)錯(cuò),如果指定了REUSE關(guān)鍵字,則將會直接覆蓋同名目標(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

  使用文件號重命名一個(gè)在線數(shù)據(jù)文件

查詢到數(shù)據(jù)文件file_to_move2.dbf所對應(yīng)的數(shù)據(jù)文件號為100,接下來,我們直接使用數(shù)據(jù)文件file_to_move2.dbf對應(yīng)的文件號(而不是具體指定其數(shù)據(jù)文件名稱及位置)將其重命名為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

 

操作完成之后,通過v$datafile視圖,確認(rèn)控制文件中也已成功修改。


向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI