缘起一个表空间太大.doc_第1页
缘起一个表空间太大.doc_第2页
缘起一个表空间太大.doc_第3页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

缘起一个表空间太大,删除数据后由于文件尾被用,无法resize,打算把所有表空间上的对象move到一个临时存储的表空间做整理。写procedure用utl_file来自动生成整理脚本,麻烦.move一个表到另外一个表空间时,索引不会跟着一起move,而且会失效。(LOB类型例外)表move,我们分为:*普通表move*分区表move*LONG,LOB大字段类型move来进行测试和说明。索引的move,我们通过rebuild来实现SQL select * from v$version;Oracle9i Enterprise Edition Release .0 - 64bit ProductionPL/SQL Release .0 - ProductionCORE .0 ProductionTNS for Solaris: Version .0 - ProductionNLSRTL Version .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;重建局部索引:=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_TABLESUSER_IND_PARTITIONSUSER_IND_SUBPARTITIONSUSER_LOB_PARTITIONSUSER_LOB_SUBPARTITIONSUSER_PART_INDEXESUSER_PART_LOBS可查询分区相关内容,同时,分区对象,也是segment,所以也可在dba_segments里查的到。三:move LONG,LOB类型据说DBMS_REDEFINITION包可以提供一些方便,没用过。I:LONG类型long类型不能通过MOVE来传输特别提示,尽量不要用LONG类型,特难管理。参考:/2005/12/long_vs_lob.html1,LONG不能使用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;beginopen cur_t123;loopfetch 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;/对有LONG类型字段的表的转移,可以使用:create新表的方法。* create一个新的表,存储在需要转移的表空间。* 创建新的索引(使用tablespace 子句指定新的表空间)。* 把数据转移过来方法一:用COPY的方法:copy from bigboar/bigboarbigboar_sid insert t123(id,en) using select id,en from t123;方法二:PL/SQL(如上)方法三:直接就把LONG转换成CLOB类型create table t321(id int,en clob) tablespace users; insert into t321(id,en) select id,to_lob(en) from t123; 方法四:exp/impexp bigboar/bigboar file=a.dat tables=t123imp bigboar/bigboar file=a.dat full=y IGNORE =y* drop掉旧表。* rename 新表为旧表表名。II:LOB类型在建立含有lob字段的表时,oracle会自动为lob字段建立两个单独的segment,一个用来存放数据(segment_type=LOBSEGMENT),另一个用来存放索引(segment_type=LOBINDEX)。默认它们会存储在和

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论