Move 表、索引、Lob、Long

原创 2007年09月20日 16:01:00
 
Move表、索引、LOB/Long [zt]




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 Production
PL
/SQL Release 9.2.0.6.0 - Production
CORE 
9.2.0.6.0 Production
TNS 
for Solaris: Version 9.2.0.6.0 - Production
NLSRTL 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;
[xsb注: 分区操作时可以带上with update global indexes选项更新全局索引。] 

重建局部索引:
================
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可查询分区相关内容,同时,分区对象,也是segment,所以也可在dba_segments里查的到。

三:move 
LONG,LOB类型(据说DBMS_REDEFINITION包可以提供一些方便,没用过。)

I:LONG类型
long类型不能通过MOVE来传输特别提示,尽量不要用LONG类型,特难管理。参考:http:
//www.anysql.net/2005/12/long_vs_lob.html
1,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;
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;
/

对有LONG类型字段的表的转移,可以使用:
create新表的方法。
* create一个新的表,存储在需要转移的表空间。
* 创建新的索引(使用tablespace 子句指定新的表空间)。
* 把数据转移过来
方法一:用COPY的方法:
copy 
from bigboar/bigboar@bigboar_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/imp
exp bigboar/bigboar file=a.dat tables=t123
imp bigboar
/bigboar file=a.dat full=y IGNORE =y
* drop掉旧表。
* rename 新表为旧表表名。

II: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);

相关文章推荐

87、Move 表、索引、Lob、Long

move一个表到另外一个表空间时,索引不会跟着一起move,而且会失效。(LOB类型例外) 表move,我们分为: *普通表move *分区表move *LONG,LOB大字段类型move来进...
  • shRootm
  • shRootm
  • 2012年03月12日 13:20
  • 135

move lob会不会影响其他索引状态?

前几天在客户现场做升级,脚本中move lob字段了,客户继续执行操作的时候,喊索引失效了。经查看,是非lob字段的索引失效,当时没注意,直接rebuild了,半夜回去的路上,经理问我,move lo...

ORA-22992:无法使用从远处表选择LOB定位器

ORA-22992无法使用从远程表选择的 LOB 定位器    错误异常:[Error] Execution (1: 1): ORA-22992: 无法使用从远程表选择的 LOB 定位器 ...

drop 一张3.7T的含lob的分区表

drop 一张3.7T的含lob的分区表 上一篇 / 下一篇  2008-12-08 21:11:33 查看( 375 ) / 评论( 1 ) / 评分( 5 / 0 ) ...

DB2表的LOB字段为什么没有使用指定的表空间

问题描述: DB2中的LOB字段并未占用指定的表空间。 创建表T2,指定LOB字段使用表空间LONGTBS,但插入一些数据之后,发现LONGTBS表空间使用并未增长。 $ db2 "create ...

回收带Lob字段表占用的空间

SQL> select object_name from user_objects; no rows selected SQL> select segment_name from user_seg...

ORA-22992: 无法使用从远程表选择的 LOB 定位器

执行:     insert into incomesec.tp_ts_bill_info_b select * from incomesec.tp_ts_bill_info_b@DB_SYDB...

lob表中出现坏块的处理方法

lob表中出现坏块的处理方法 1)创建lob 表 SQL> create table lobdemo(a number,b clob)      2  lob(b) store as (...

Oracle中查询带有lob字段的表的大小

Oracle中 lob字段采用独立的lob segment来存储,因此表的大小不能只查看dba_segments. mos给出了查询语句: How to Compute the Siz...

@Lob字段在@Column中使用nullable=false导致hibernate无法自动建表

定义了一个报告类,其中报告内容content使用@Lob定义为大数据字段@Embeddable public class ReportPo { @Column(name="report_title...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Move 表、索引、Lob、Long
举报原因:
原因补充:

(最多只允许输入30个字)