【Oracle】How to Rename or Move Datafiles and Logfiles 之二
在資料庫open狀態下進行重新命名或者遷移資料檔案:
注意:遷移system 表空間裡的資料檔案或者redo log 必須在mount狀態下進行操作。
在資料庫open 模式進行資料檔案的移動時,資料檔案所在的表空間必須是隻讀的。使用者只可以進行select 查詢操作而不能進行DML 修改。此期間持續的時間由遷移的資料檔案大小和copy到新的目錄的時間決定!
具體步驟如下:
1 確定有多少資料檔案要進行遷移, 確保所有檔案的status 為 AVAILABLE
SYS@yangdb-rac3> col file_name for a50
SYS@yangdb-rac3> SELECT FILE_NAME, STATUS FROM DBA_DATA_FILES WHERE TABLESPACE_NAME = 'USERS';
FILE_NAME STATUS
-------------------------------------------------- ---------
/opt/oracle/oradata/yangdb_test/users01.dbf AVAILABLE
2設定表空間為只讀,確保表空間已經在資料庫字典裡面設定為只讀
SYS@yangdb-rac3> alter tablespace users read only;
Tablespace altered.
SYS@yangdb-rac3> SELECT TABLESPACE_NAME, STATUS FROM DBA_TABLESPACES WHERE TABLESPACE_NAME = 'USERS';
TABLESPACE_NAME STATUS
------------------------------ ---------
USERS READ ONLY
3 移動資料檔案到新的位置
oracle@rac3:/opt/oracle/oradata/yangdb_test>ls
control01.ctl control02.ctl control03.ctl example01.dbf redo01.log redo02.log redo03.log sysaux01.dbf system01.dbf temp01.dbf undotbs01.dbf users01.dbf
oracle@rac3:/opt/oracle/oradata/yangdb_test>cp users01.dbf ../yangdb/users01.dbf
oracle@rac3:/opt/oracle/oradata/yangdb_test>cd ../yangdb
oracle@rac3:/opt/oracle/oradata/yangdb>ls
users01.dbf
4 當資料檔案已經被遷移到新的位置,將表空間offline
SYS@yangdb-rac3> ALTER TABLESPACE USERS OFFLINE;
Tablespace altered.
查詢表空間的status 資訊
SYS@yangdb-rac3> SELECT TABLESPACE_NAME, STATUS FROM DBA_TABLESPACES WHERE TABLESPACE_NAME = 'USERS';
TABLESPACE_NAME STATUS
------------------------------ ---------
USERS READ ONLY
資料檔案的status
SYS@yangdb-rac3> SELECT FILE_NAME, STATUS FROM DBA_DATA_FILES WHERE TABLESPACE_NAME = 'USERS';
FILE_NAME STATUS
-------------------------------------------------- ---------
/opt/oracle/oradata/yangdb_test/users01.dbf AVAILABLE
SYS@yangdb-rac3> select name,status from v$datafile;
NAME STATUS
-------------------------------------------------- -------
/opt/oracle/oradata/yangdb_test/system01.dbf SYSTEM
/opt/oracle/oradata/yangdb_test/sysaux01.dbf ONLINE
/opt/oracle/oradata/yangdb_test/undotbs01.dbf ONLINE
/opt/oracle/oradata/yangdb_test/users01.dbf OFFLINE
/opt/oracle/oradata/yangdb_test/example01.dbf ONLINE
5 重新命名資料檔案,此步驟將修改控制檔案裡的相關資訊
SYS@yangdb-rac3> alter database rename file '/opt/oracle/oradata/yangdb_test/users01.dbf' to '/opt/oracle/oradata/yangdb/users01.dbf';
Database altered.
6 將資料檔案重新命名後,將表空間設定為online,並且將其設定為read write
SYS@yangdb-rac3> ALTER TABLESPACE USERS ONLINE;
Tablespace altered.
SYS@yangdb-rac3> select name,status from v$datafile;
NAME STATUS
-------------------------------------------------- -------
/opt/oracle/oradata/yangdb_test/system01.dbf SYSTEM
/opt/oracle/oradata/yangdb_test/sysaux01.dbf ONLINE
/opt/oracle/oradata/yangdb_test/undotbs01.dbf ONLINE
/opt/oracle/oradata/yangdb/users01.dbf ONLINE
/opt/oracle/oradata/yangdb_test/example01.dbf ONLINE
SYS@yangdb-rac3> SELECT TABLESPACE_NAME, STATUS FROM DBA_TABLESPACES WHERE TABLESPACE_NAME = 'USERS';
TABLESPACE_NAME STATUS
------------------------------ ---------
USERS READ ONLY
SYS@yangdb-rac3> ALTER TABLESPACE USERS READ WRITE;
Tablespace altered.
SYS@yangdb-rac3> SELECT TABLESPACE_NAME, STATUS FROM DBA_TABLESPACES WHERE TABLESPACE_NAME = 'USERS';
TABLESPACE_NAME STATUS
------------------------------ ---------
USERS ONLINE
SYS@yangdb-rac3> SELECT TABLESPACE_NAME, STATUS FROM DBA_TABLESPACES WHERE TABLESPACE_NAME = 'USERS';
TABLESPACE_NAME STATUS
------------------------------ ---------
USERS ONLINE
7 測試結果,查詢users 表空間中的資料:
SYS@yangdb-rac3> SELECT COUNT(*) FROM SCOTT.EMP;
COUNT(*)
----------
14
成功!
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/22664653/viewspace-708992/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Rename or Move a datafile In Oracle 19c RAC-20220117Oracle
- how to move a MediaWiki wiki from one server to anotherServer
- oracle 分割槽表move和包含分割槽表的lob moveOracle
- oracle 線上rename資料檔案Oracle
- How Oracle Store Number internal(zt)Oracle
- Oracle move和shrink釋放高水位空間Oracle
- How to Install EMC PowerPath on Oracle VM 3.4Oracle
- Oracle 12.2 新特性: Online PDB relocate (PDB hot move)Oracle
- How To Deal With Split Brain In Oracle 19c RacAIOracle
- Oracle 12.2 How to Generate AWRs in Active Data Guard Standby DatabasesOracleDatabase
- Oracle redo日誌內容探索之二Oracle Redo
- Oracle for Windows安裝和配置之二OracleWindows
- [20221222]How to Enable and Disable Database Options in oracle 11g.txtDatabaseOracle
- How To Deal With Split Brain In Oracle 19c Rac-202203AIOracle
- How To Replicate Data from Oracle to Postgres Using GoldenGate (Doc ID 1544137.1OracleGo
- WPF mvvm canvas move elements via mouse down, up and move eventsMVVMCanvas
- MySQL rename table方法大全MySql
- LeetCode—283—Move ZeroesLeetCode
- Thread: ADMU3011E: Server launched but failed initialization. Server logfiles shthreadServerAI
- Oracle 12c RAC構築之二:共享磁碟配置Oracle
- os.walk、os.rename
- WPF Image zoomin zoomout moveOOM
- 非OMF管理 自動新增資料檔案add_datafiles.sh
- How to ssh
- Linux rename命令批量修改檔名Linux
- alter table move與shrink space
- Office365 OneDrive Geo Move
- 12C 線上MOVE
- SAP Move to Rise是什麼意思? SAP Move的五條路徑是什麼?
- Linux常用基本命令(rename,basename,dirname)Linux
- [20231025]跟蹤rename操作2.txt
- Redis原始碼系列之rename講解Redis原始碼
- How to find dependency
- 每週一算:Move ZerosROS
- C++ 逆向之 move 函式C++函式
- HFR:在RBF上實現跨NameSpace Renamenamespace
- [譯] WebAssembly: How and whyWeb
- How OpenStack integrates with Ceph?
- How to Build a Cybersecurity CareerUI