表空間概述
Oracle的表空間屬于Oracle中的存儲(chǔ)結(jié)構(gòu),是一種用于存儲(chǔ)數(shù)據(jù)庫(kù)對(duì)象(如:數(shù)據(jù)文件)的邏輯空間,是Oracle中信息存儲(chǔ)的最大邏輯單元,其下還包含有段、區(qū)、數(shù)據(jù)塊等邏輯數(shù)據(jù)類型。表空間是在數(shù)據(jù)庫(kù)中開辟的一個(gè)空間,用于存放數(shù)據(jù)庫(kù)的對(duì)象,一個(gè)數(shù)據(jù)庫(kù)可以由多個(gè)表空間組成??梢酝ㄟ^表空間來實(shí)現(xiàn)對(duì)Oracle的調(diào)優(yōu)。(Oracle數(shù)據(jù)庫(kù)獨(dú)特的高級(jí)應(yīng)用)
表空間的分類
永久表空間:存儲(chǔ)數(shù)據(jù)庫(kù)中需要永久化存儲(chǔ)的對(duì)象,比如二維表、視圖、存儲(chǔ)過程、索引。
臨時(shí)表空間:存儲(chǔ)數(shù)據(jù)庫(kù)的中間執(zhí)行過程,如:保存order by數(shù)據(jù)庫(kù)排序,分組時(shí)產(chǎn)生的臨時(shí)數(shù)據(jù)。操作完成后存儲(chǔ)的內(nèi)容會(huì)被自動(dòng)釋放。臨時(shí)表空間是通用的,所的用戶都使用TEMP作為臨時(shí)表空間。一般只有tmp一個(gè)臨時(shí)表空間,如果還需要?jiǎng)e的臨時(shí)表空間時(shí),可以自己創(chuàng)建。
UNDO表空間:保存數(shù)據(jù)修改前的副本。存儲(chǔ)事務(wù)所修改的舊址,即被修改之前的數(shù)據(jù)。當(dāng)我們對(duì)一張表中的數(shù)據(jù)進(jìn)行修改的同時(shí)會(huì)對(duì)修改之前的信息進(jìn)行保存,為了對(duì)數(shù)據(jù)執(zhí)行回滾、恢復(fù)、撤銷的操作。
引言
Oracle數(shù)據(jù)庫(kù)的數(shù)據(jù)文件的位置和信息都被記錄在控制文件中,rm或cp命令是不會(huì)也不可能更改控制文件記錄的,這時(shí)必須通過alter操作去更改刷新數(shù)據(jù)庫(kù)控制文件中數(shù)據(jù)文件的相關(guān)信息,以此確保數(shù)據(jù)庫(kù)能夠正常運(yùn)行。
操作方法
1. 方法1
主要步驟:
1、offline表空間:alter tablespace tablespace_name offline;
2、復(fù)制數(shù)據(jù)文件到新的目錄;
3、rename修改表空間,并修改控制文件;
4、online表空間;
offline表空間
SQL> alter tablespace cifdb offline;
復(fù)制數(shù)據(jù)文件到新的目錄
cp /u01/app/oracle/oradata/cifdb.dbf /u01/app/oracle/oradata/CIFDB/cifdb.dbf
rename修改表空間
SQL> alter tablespace cifdb rename datafile '/u01/app/oracle/oradata/cifdb.dbf' to '/u01/app/oracle/oradata/CIFDB/cifdb.dbf';
online表空間
SQL> alter tablespace cifdb online;
檢查數(shù)據(jù)文件
SQL> select name from v$datafile;
或者
SQL> select file_name, tablespace_name from dba_data_files where tablespace_name='cifdb';
2. 方法2
主要步驟:
1、關(guān)閉數(shù)據(jù)庫(kù);
2、復(fù)制數(shù)據(jù)文件到新的位置;
3、啟動(dòng)數(shù)據(jù)庫(kù)到mount狀態(tài);
4、通過SQL修改數(shù)據(jù)文件位置;
5、打開數(shù)據(jù)庫(kù);
關(guān)閉數(shù)據(jù)庫(kù)
復(fù)制數(shù)據(jù)文件到新的位置
cp /u01/app/oracle/oradata/cifdb.dbf /u01/app/oracle/oradata/CIFDB/cifdb.dbf
啟動(dòng)數(shù)據(jù)庫(kù)到mount狀態(tài)
修改數(shù)據(jù)文件位置
SQL> alter database rename file '/u01/app/oracle/oradata/cifdb.dbf' to '/u01/app/oracle/oradata/CIFDB/cifdb.dbf';
打開數(shù)據(jù)庫(kù)
SQL> alter database open;
檢查數(shù)據(jù)文件
SQL> select name from v$datafile;
或者
SQL> select file_name, tablespace_name from dba_data_files where tablespace_name='cifdb';
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
您可能感興趣的文章:- Oracle表空間數(shù)據(jù)文件移動(dòng)的方法
- Oracle7.X 回滾表空間數(shù)據(jù)文件誤刪除處理方法
- Oracle7.X 回滾表空間數(shù)據(jù)文件誤刪除處理方法
- Oracle7.X 回滾表空間數(shù)據(jù)文件誤刪除處理方法
- Oracle如何設(shè)置表空間數(shù)據(jù)文件大小