1. 首页
  2. IT资讯

Oracle 表的移动和索引的重建

from:space.itpub.net/spacecp.php?action=spaceblogs&op=add

Oracle 表的移动和索引的重建

缘起一个表空间太大,删除数据后由于文件尾被用,无法resize,打算把所有表空间上的对象move到一个临时存储的表空间做整理。 move一个表到另外一个表空间时,索引不会跟着一起move,而且会失效。(LOB类型例外)表move,我们分为:*普通表move*分区表move*LONG,LOB大字段类型move来进行测试和说明。索引的move,我们通过rebuild来实现SQL> select * from v$version;Oracle9i Enterprise Edition Release 9.2.0.6.0 – 64bit ProductionPL/SQL Release 9.2.0.6.0 – ProductionCORE 9.2.0.6.0 ProductionTNS for Solaris: Version 9.2.0.6.0 – ProductionNLSRTL Version 9.2.0.6.0 – Production一:move普通表、索引基本语法:alter table tab_name move tablespace tbs_name;move过的普通表,在不用到失效的索引的操作语句中,语句执行正常,但如果操作的语句用到了索引(主键当做唯一索引),则此时报告用到的索引失效,语句执行失败,其他如外键,非空约束,缺省值等不会失效。我们需要重新创建主键或索引,基本语法为:alter index index_name rebuild;alter index pk_name rebuild;如果我们需要move索引,则使用rebuild语法:alter index index_name rebuild tablespace tbs_name;alter index pk_name rebuild tablespace tbs_name;提示:查询表所具有的索引,可以使用user_indexes视图(索引和主键都在这个视图里可找到)。二:move分区表及索引和普通表一样,索引会失效,区别的仅仅是语法而已。分区基本语法:特别提醒注意,如果是单级分区,则使用关键字PARTITION,如果是多级分区,则使用SUBPARTITION替代PARTITION。如果分区或分区索引比较大,可以使用并行move或rebuild,PARALLEL (DEGREE 2);如:ALTER TABLE PART_ALARMTEXTDATA move SUBPARTITION ALARMTEXTDATA_050910_ATD01 TABLESPACE users PARALLEL (DEGREE 2);ALTER INDEX GLOBAL_ALARMTEXTDATA REBUILD tablespace users PARALLEL (DEGREE 2);ALTER INDEX LOCAL_ALARMTEXTDATA REBUILD SUBPARTITION ALARMTEXTDATA_050910_ATD01 TABLESPACE users PARALLEL (DEGREE 2);移动表的某个分区:================ALTER TABLE tab_name move PARTITION partition_name TABLESPACE tbs_name;重建全局索引:================ALTER INDEX global_index REBUILD;或ALTER INDEX global_index REBUILD tablespace tbs_name; ……

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/27042095/viewspace-759882/,如需转载,请注明出处,否则将追究法律责任。

主题测试文章,只做测试使用。发布者:布吉卡,转转请注明出处:http://www.cxybcw.com/196039.html

联系我们

13687733322

在线咨询:点击这里给我发消息

邮件:1877088071@qq.com

工作时间:周一至周五,9:30-18:30,节假日休息

QR code