`
ticojj
  • 浏览: 156667 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

Oracle tablespace partition Move

 
阅读更多
Oracle的Move操作 move一个表到另外一个表空间时,索引不会跟着一起move,而且会失效。(LOB类型例外)

 

表move,我们分为:

*普通表move

*分区表move

*LONG,LOB大字段类型move来进行测试和说明。

 

索引的move,我们通过rebuild来实现

一: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;注: 分区操作时可以带上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

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);
分享到:
评论

相关推荐

    如何保持Oracle数据库优良性能

    MOVE PARTITION`可以在不同表空间之间移动分区。 - **修改分区**:使用`ALTER TABLE ... SPLIT PARTITION`来分裂一个分区成两个。 - **重命名分区**:通过`ALTER TABLE ... RENAME PARTITION`更改分区名称。 - **...

    oracle分区表多个关键字请用空格分隔,最多填写5个。点击右侧Tag快速添加

    ALTER TABLE BILL_MONTHFEE_ZERO MOVE PARTITION p_200409 TABLESPACE TS_ZIKEN_01 NOLOGGING; ``` ### 查询分区表 对于分区表的查询操作,可以直接针对整个表或者指定具体的分区进行查询: ```sql -- 查询p_...

    oracle修改表空间的全部步骤,包含bob,clob字段

    ALTER TABLE 表名 MOVE PARTITION 分区名 TABLESPACE 新表空间名; ``` 重复此操作直至所有需要移动的分区都已完成。 #### 6. 验证与测试 完成所有修改后,务必验证数据的完整性和一致性,确保所有对象都已成功...

    创建导入导出Oracle分区表数据[参照].pdf

    ALTER TABLE bill_monthfee_zero MOVE PARTITION p_200409 TABLESPACE ts_ziken_01 NOLOGGING; ``` 查询特定分区的数据: ```sql SELECT COUNT(*) FROM BILL_MONTHFEE_ZERO PARTITION (p_200407); ``` 向分区中...

    oracle分区表学习与应用

    ALTER TABLE bill_monthfee_zero MOVE PARTITION p_200409 TABLESPACE ts_ziken_01 NOLOGGING; ``` 7. **查询特定分区**:可以直接针对特定分区执行查询,以获取该分区中的数据。 ```sql SELECT COUNT(*) FROM ...

    ORACLE重建索引总结

    使用`ALTER INDEX indexname REBUILD PARTITION partitionname TABLESPACE tablespacename`或`ALTER INDEX indexname REBUILD SUBPARTITION partitioname TABLESPACE tablespacename`命令,可以根据需要改变索引的...

    分区索引,本地索引,全局索引的区别

    PARTITION p3 VALUES LESS THAN (MAXVALUE) TABLESPACE p3 ); CREATE INDEX i_id ON test (id) LOCAL; CREATE INDEX i_data ON test (data) LOCAL; ``` 在上述例子中,`i_id` 是一个有前缀的本地索引,因为它...

    oracel 分区表索引失效的问题

    ### Oracle 分区表索引失效的问题 #### 一、全局索引与分区表的关系 **全局索引**(Global Index)是指索引覆盖整个表的所有数据,而不受限于分区边界。这种类型的索引通常用于非分区列或者跨分区查询。 **实验...

    如何保持Oracle数据库的优良性能

    partition PART1 values less than (11) tablespace PART1_TS, partition PART2 values less than(21) tablespace PART2_TS, partition PART3 valuse less than(31) tablespace PART3_TS, partition PART4 ...

    Oracle事例

    sql> create user juncky identified by oracle default tablespace users sql> temporary tablespace temp quota 10m on data password expire sql> [account lock|unlock] [profile profilename|default]; ...

    数据库坏块(ORA-01578)的解决方法.pdf

    ALTER TABLE <表名> MOVE PARTITION <分区名> TABLESPACE <表空间名>; ``` ### ROWID检测法 1. 使用ROWID函数来检测坏块,例如: ```sql SELECT ROWID FROM <表名> WHERE <条件>; ``` 2. 使用ROWID结果来定位坏块,...

Global site tag (gtag.js) - Google Analytics