移动表空间所使用的脚本以及语句

来源:互联网 发布:antpool矿池挖矿软件 编辑:程序博客网 时间:2024/06/05 14:10
一常规移动表空间的脚本语句
select 'alter table ' || a.owner || '.' || TABLE_NAME ||
       ' move tablespace TS_DISA_DATA;'
  from dba_tables a
 where a.tablespace_name = 'TS_QBJCK'
   and owner='GAQJK';
select *
  from dba_tables a
 where a.tablespace_name = 'TS_QBJCK' and ower;


select 'alter table' || table_name || 'move lob(' || index_name ||
       ') store as (tablespace tbs_name);'
  from dba_indexes
 where wner = '%***%'
   and index_name like '%***%';


select 'alter index ' || c.owner || '.' || index_name || ' rebuild tablespace TS_DRM_META;' index_name
  from dba_indexes c
 where  c.status='UNUSABLE';


二、移动分区表和分区索引



移动分区表的表空间
 1) 非组合分区表
   alter table RPT_F_STATION_DP move  PARTITION SYS3601   tablespace ZHKDATA;
   
 2) 组合分区表:
   (1)先移动子分区到另一个表空间 :
   alter table RPT_F_CABECF move  SUBPARTITION SYS_SUB2 tablespace ZHKDATA;  
   
   (2)subpartition已经move走了,就剩下subpartition的father了,那就不需要move了,改一下分区的属性就可以了。
   ALTER TABLE T_BS_RK_CZRK MODIFY DEFAULT ATTRIBUTES FOR  PARTITION PARTITION_3601  TABLESPACE ZHKDATA;
   
注:
如直接move含有子分区的分区将发生如下错误
ORA-14257: cannot move partition other than a Range or Hash partition    
   
移动分区表上index的表空间
1)非分区index
  ALTER INDEX PK_RPT_F_NOFINISH_WORKSHEET REBUILD TABLESPACE ZHKDATA;
  
2)无子分区的index   
  ALTER INDEX IDX_RPT_F_STATION_DP_1 REBUILD PARTITION SYS_WB01  TABLESPACE ZHKDATA;  
  
3)子分区index
ALTER INDEX IDX_RPT_F_CABECF_1 REBUILD SUBPARTITION SYS_WB012 TABLESPACE ZHKDATA;


四、自动生成需要的脚本
SELECT    'alter table '
       || table_name
       || ' move  PARTITION '
       || partition_name
       || ' tablespace ZHKDATA;'
  FROM USER_TAB_PARTITIONS
 WHERE SUBPARTITION_COUNT = 0 AND tablespace_name = 'TS_ZHKJCK'; -- 非组合分区表
 
SELECT    'alter table '
       || table_name
       || ' move  subPARTITION '
       || SUBPARTITION_NAME
       || ' tablespace ZHKDATA;'
  FROM USER_TAB_SUBPARTITIONS
 WHERE SUBPARTITION_COUNT > 0 AND tablespace_name = 'TS_ZHKJCK';  --移动子分区
SELECT    'ALTER TABLE '
       || table_name
       || ' MODIFY DEFAULT ATTRIBUTES FOR  PARTITION '
       || partition_name
       || '  TABLESPACE ZHKDATA;'
  FROM USER_TAB_PARTITIONS
 WHERE SUBPARTITION_COUNT > 0 AND tablespace_name = 'TS_ZHKJCK';--修改母分区属性 
 
 SELECT 'ALTER INDEX ' || INDEX_NAME || ' REBUILD TABLESPACE ZHKDATA;'
  FROM USER_INDEXES
 WHERE tablespace_name='TS_ZHKJCK';
 
 
SELECT    'ALTER INDEX '
       || index_name
       || ' REBUILD PARTITION '
       || PARTITION_NAME
       || ' TABLESPACE ZHKDATA; '
  FROM USER_IND_PARTITIONS
  where SUBPARTITION_COUNT = 0
    and tablespace_name='TS_ZHKJCK'; -- 无子分区的index
    
SELECT    'ALTER INDEX '
       || index_name
       || ' REBUILD SUBPARTITION '
       || SUBPARTITION_NAME
       || ' TABLESPACE ZHKDATA; '
  FROM USER_IND_SUBPARTITIONS
    where tablespace_name='TS_ZHKJCK'; --子分区index
无、特殊的表


使用上面语句对表做空间迁移时,只能移动非lob字段以外的数据,如果要同时移动lob字段数据,必需改用下面的语句才行:
alter table tb_name move tablespace tbs_name lob (col_lob1,col_lob2) store as (tablesapce tbs_name);
0 0