ORACLE MOVE表空間

聽海★藍心夢發表於2010-11-16

move一個表到另外一個表空間時,索引不會跟著一起move,而且會失效(LOB型別例外)。做表空間轉移之前,被轉移表的使用者必須在目的表空間上有使用表空間的許可權,否則會報錯:ORA-01950: no privileges on tablespace...

move分為

1.普通表move

2.分割槽表move

3.LONG

4.LOB大欄位型別move

5.索引的move透過rebuild來實現

一、move普通表、索引

1、基本語法:

aalter table table_name t move tablespace xxx;

balter index index_name rebuild tablespace xxx;

move過的普通表,在不用到失效的索引的操作語句中,語句執行正常,但如果操作的語句用到了索引(主鍵當做唯一索引),則此時報告用到的索引失效,語句執行失敗,其他如外來鍵,非空約束,預設值等不會失效。

2、重新建立主鍵或索引基本語法為:

aalter index index_name rebuild;

balter index pk_name rebuild;

3move索引用rebuild語法:

aalter index index_name rebuild tablespace tbs_name;

balter index pk_name rebuild tablespace tbs_name;

二、move分割槽表及索引

和普通表一樣,分割槽表索引會失效,區別的僅僅是語法而已。

1、分割槽基本語法

注:如果是單級分割槽,則使用關鍵字PARTITION,如果是多級分割槽,則使用SUBPARTITION替代PARTITION

如果分割槽或分割槽索引比較大,可以使用並行moverebuildPARALLEL (DEGREE 2);

如:

ALTER TABLE PART_ALARM move SUBPARTITION p_01 TABLESPACE users PARALLEL (DEGREE 2);

--全域性索引

ALTER INDEX GX1_ PART_ALARM REBUILD tablespace users PARALLEL (DEGREE 2);

--分割槽索引

ALTER INDEX LX1_ PART_ALARM REBUILD SUBPARTITION p_01 TABLESPACE users1 PARALLEL (DEGREE 2);

ALTER INDEX LX1_ PART_ALARM REBUILD SUBPARTITION p_02 TABLESPACE users2 PARALLEL (DEGREE 2);

………………

ALTER INDEX LX1_ PART_ALARM REBUILD SUBPARTITION p_0n TABLESPACE usersn PARALLEL (DEGREE 2);

2、移動表的某個分割槽

ALTER TABLE tab_name move PARTITION partition_name TABLESPACE tbs_name;

3、重建全域性索引

ALTER INDEX global_index REBUILD;

ALTER INDEX global_index REBUILD tablespace tbs_name;

4、重建區域性索引

ALTER TABLE tab_name MODIFY PARTITION partition_name REBUILD UNUSABLE LOCAL INDEXES;

ALTER INDEX local_index_name REBUILD PARTITION partition_name TABLESPACE tbs_name;

 

提示:

USER_PART_TABLES

USER_IND_PARTITIONS

USER_IND_SUBPARTITIONS

USER_LOB_PARTITIONS

USER_LOB_SUBPARTITIONS

USER_PART_INDEXES

USER_PART_LOBS

user_segments

三、move LONG型別

可以使用DBMS_REDEFINITION包可以提供一些方便,不過沒用過。

long型別不能透過MOVE來傳輸。特別提示,儘量不要用LONG型別,特難管理。

1LONG不能使用insert into ... select ...等帶select的模式。

create table t123 (id int,en long);

insert into t123(id,en) select * from t123;

報告錯誤,可以用pl/sql來幫助解決,如:

declare

cursor cur_t123 is select * from t123;

use_t123 cur_t123%rowtype;

begin

 

open cur_t123;

loop

fetch cur_t123 into use_t123;

exit when cur_t123%notfound;

 

insert into t123(id,en) values (use_t123.id,use_t123.en);

 

end loop;

close cur_t123;

 

end;

/

2LONG型別欄位的表的轉移

1.)create新表的方法。

a.create一個新的表,儲存在需要轉移的表空間。

b.建立新的索引(使用tablespace 子句指定新的表空間)。

c.把資料轉移過來

2.)COPY的方法

copy from bigboar/bigboar@bigboar_sid insert t123(id,en) using select id,en from t123;

3、直接就把LONG轉換成CLOB型別

create table t321(id int,en clob) tablespace users;

insert into t321(id,en) select id,to_lob(en) from t123;

4exp/imp

exp bigboar/bigboar file=a.dat tables=t123

imp bigboar/bigboar file=a.dat full=y IGNORE =y

a.drop掉舊錶。

b.rename 新表為舊錶表名。

四、LOB型別

在建立含有lob欄位的表時,oracle會自動為lob欄位建立兩個單獨的segment,一個用來存放資料(segment_type=LOBSEGMENT),另一個用來存放索引(segment_type=LOBINDEX)。預設它們會儲存在和表一起的表空間。我們對錶MOVE時,LOG型別欄位和該欄位的索引不會跟著MOVE,必須要單獨來進行MOVE,語法如下如:

alter table t321 move tablespace users;

alter table t321 move lob(en) store as (tablespace users);

大家都知道在我們建立含有lob欄位的表時,oracle會自動為lob欄位建立兩個單獨的segment,一個用來存放資料,另一個用來存放索引,並且它們都會儲存在對應表指定的表空間中。但是當我們用alter table tb_name move tablespace tbs_name;來對錶做空間遷移時只能移動非lob欄位以外的資料,而如果我們要同時移動lob相關欄位的資料,我們就必需用如下的含有特殊引數據的文句來完成:

alter table tb_name move tablespace tbs_name lob (col_lob1,col_lob2) store as(tablesapce tbs_name);

五、實際工作操作示例

1、說明

SOURCE_TABLESPACE表空間上的表移動到DEST_TABLESPACE表空間上,刪除SOURCE_TABLESPACE,釋放磁碟空間,重新再建一個比原先小的SOURCE_TABLESPACE表空間,再把表移回SOURCE_TABLESPACE

2、步驟

1.) 檢查表空間表欄位有沒有分割槽、包含LOB欄位和LONG欄位等

 

2.)  檢查表空間有什麼內容(包括表、索引、分割槽等)

select segment_name,segment_type from dba_segments where tablespace_name=' SOURCE_TABLESPACE';

 

3.)  移動表和索引

alter table IBSS.TB_CM_MSPARAM_HIST move tablespace DEST_TABLESPACE;

alter table IBSS.TB_CM_SPRESENT_HIST move tablespace DEST_TABLESPACE;

alter table IBSS.TB_CM_MSSRVLTD_HIST move tablespace DEST_TABLESPACE;

alter table IBSS.TB_CM_MSITEM_HIST move tablespace DEST_TABLESPACE;

alter table IBSS.TB_CM_MSOBJECT_HIST move tablespace DEST_TABLESPACE;

alter table IBSS.TB_CM_MSOBJGRP_HIST move tablespace DEST_TABLESPACE;

alter table IBSS.TB_CM_SERVACCT_HIST move tablespace DEST_TABLESPACE;

alter table IBSS.TB_CM_BANKACCT_HIST move tablespace DEST_TABLESPACE;

alter table IBSS.TB_CM_ACCT_HIST move tablespace DEST_TABLESPACE;

alter table IBSS.TB_CM_MSINFO_HIST move tablespace DEST_TABLESPACE;

alter table IBSS.TB_CM_MSITEMR_HIST move tablespace DEST_TABLESPACE;

 

alter index IBSS.IX_CM_MSINFOUST rebuild tablespace DEST_TABLESPACE;

alter index IBSS.IX_CM_MSINMSINF rebuild tablespace DEST_TABLESPACE;

alter index IBSS.IX_CM_MSIN _DISC rebuild tablespace DEST_TABLESPACE;

alter index IBSS.IX_CM_MSITEMNG rebuild tablespace DEST_TABLESPACE;

alter index IBSS.IX_CM_MSOBJE ID rebuild tablespace DEST_TABLESPACE;

alter index IBSS.IX_CM_M_MSINFO rebuild tablespace DEST_TABLESPACE;

alter index IBSS.IX_CM_MSOBJET rebuild tablespace DEST_TABLESPACE;

alter index IBSS.IX_CM_MSPRINFO rebuild tablespace DEST_TABLESPACE;

 

4.)  刪除表空間SOURCE_TABLESPACE

DROP TABLESPACE HPMDBS1 INCLUDING CONTENTS and DATAFILES;

 

5.)  重新建立表空間

CREATE TABLESPACE HPMDBS1 DATAFILE

  '/opt/oracle/oradata1/tbs0101.dbf' SIZE 6192M AUTOEXTEND OFF;

 

6.)  重新移動表和索引到原空間

alter table IBSS.TB_CM_MSPARAM_HIST move tablespace SOURCE_TABLESPACE;

alter table IBSS.TB_CM_SPRESENT_HIST move tablespace SOURCE_TABLESPACE;

alter table IBSS.TB_CM_MSSRVLTD_HIST move tablespace SOURCE_TABLESPACE;

alter table IBSS.TB_CM_MSITEM_HIST move tablespace SOURCE_TABLESPACE;

alter table IBSS.TB_CM_MSOBJECT_HIST move tablespace SOURCE_TABLESPACE;

alter table IBSS.TB_CM_MSOBJGRP_HIST move tablespace SOURCE_TABLESPACE;

alter table IBSS.TB_CM_SERVACCT_HIST move tablespace SOURCE_TABLESPACE;

alter table IBSS.TB_CM_BANKACCT_HIST move tablespace SOURCE_TABLESPACE;

alter table IBSS.TB_CM_ACCT_HIST move tablespace SOURCE_TABLESPACE;

alter table IBSS.TB_CM_MSINFO_HIST move tablespace SOURCE_TABLESPACE;

alter table IBSS.TB_CM_MSITEMR_HIST move tablespace SOURCE_TABLESPACE;

 

alter index IBSS.IX_CM_MSINFOUST rebuild tablespace SOURCE_TABLESPACE;

alter index IBSS.IX_CM_MSINMSINF rebuild tablespace SOURCE_TABLESPACE;

alter index IBSS.IX_CM_MSIN _DISC rebuild tablespace SOURCE_TABLESPACE;

alter index IBSS.IX_CM_MSITEMNG rebuild tablespace SOURCE_TABLESPACE;

alter index IBSS.IX_CM_MSOBJE ID rebuild tablespace SOURCE_TABLESPACE;

alter index IBSS.IX_CM_M_MSINFO rebuild tablespace SOURCE_TABLESPACE;

alter index IBSS.IX_CM_MSOBJET rebuild tablespace SOURCE_TABLESPACE;

alter index IBSS.IX_CM_MSPRINFO rebuild tablespace SOURCE_TABLESPACE;

 

7.)  檢查原先表和索引是否正確,檢查表空間索引有沒有無效。

SELECT index_name,index_type, STATUS,partitioned, table_name

FROM User_Indexes

Where status=’UNUSABLE’;

 

六、常用SQL

       該方法可以用來釋放被表空間佔用的大量的磁碟空間,如果資料物件非常多就很麻煩。可以用以下的SQL來批次處理。

1、重建分割槽/普通表和索引的拼接sql語句

SELECT 'ALTER INDEX '||t1.owner||'.'||segment_name||' REBUILD '||''||

        CASE WHEN t1.segment_type = 'INDEX PARTITION' THEN 'PARTITION '||partition_name

             WHEN t1.segment_type = 'INDEX SUBPARTITION' THEN 'SUBPARTITION '||partition_name

        ELSE ''

        END

        ||' tablespace '||'&DEST_TABLESPACE'||';'

FROM dba_segments t1

WHERE tablespace_name='&SOURCE_TABLESPACE' AND segment_type IN ('INDEX','INDEX PARTITION','INDEX SUBPARTITION')

UNION

SELECT 'ALTER TABLE '||t1.owner||'.'||segment_name||' MOVE '||''||

        CASE WHEN t1.segment_type = 'TABLE PARTITION' THEN 'PARTITION '||partition_name

             WHEN t1.segment_type = 'TABLE SUBPARTITION' THEN 'SUBPARTITION '||partition_name

        ELSE ''

        END

        ||' tablespace '||'&DEST_TABLESPACE'||';'

FROM dba_segments t1

WHERE tablespace_name='&SOURCE_TABLESPACE' AND segment_type IN ('TABLE','TABLE PARTITION')

ORDER BY 1 DESC;

 

2、轉移LOB欄位SQL

SELECT 'ALTER TABLE '||t2.owner||'.'||t2.table_name||' move lob ('||t1.segment_name||')'||' STORE AS ('||' tablespace '||&end_tablespace||');'

FROM dba_segments t1,dba_lobs t2

WHERE t1.segment_name=t2.segment_name AND tablespace_name='&source_tablespace' AND segment_type IN ('LOBINDEX','LOBSEGMENT','LOB PARTITION');

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/751371/viewspace-678238/,如需轉載,請註明出處,否則將追究法律責任。

相關文章