role之精解:来自puber西瓜
查看( 262 ) /
评论( 11 )
TAG:
-
wisdomone1
发布于2008-05-20 23:50:03
-
再次谢谢西瓜.
-
五“宅”一生发布于2008-05-21 00:18:15
-
谢谢西瓜,谢谢楼主。
-
luo_813
发布于2008-05-21 00:37:29
-
谢谢西瓜
学习了
以后的好好总结
-
wisdomone1
发布于2008-05-21 02:30:40
-
转自puber(我的猪窝)
表整理之:move表或索引汇总
缘起一个表空间太大,删除数据后由于文件尾被用,无法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 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;
重建局部索引:
================
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);
-
xiaodong_1567
发布于2008-05-21 08:06:27
-
thanks
-
Alienovo
发布于2008-05-21 09:07:09
-
谢谢分享!
-
carcase发布于2008-05-21 09:56:48
-
总结的不错
-
阿日
发布于2008-05-21 10:31:23
-
不错,我想问一下
我按move的方式进行操作步骤如下
在表空间fttest中建立了一个表 test1,并建立了相关索引
SQL> connect fttest/fttest
已连接。
SQL> create table test1(id int,name varchar2(10));
SQL> alter table test1 add constraint pk_test1 primary key(id);
表已更改。
SQL> create index idx1 on test1(id,name);
索引已创建。
利用move命令
SQL> connect /as sysdba
已连接。
SQL> alter table fttest.test1 move tablespace ftitem10g;
表已更改。
SQL> connect ftitem/ftitem;
已连接。
SQL> select * from test1;
select * from test1
*
第 1 行出现错误:
ORA-00942: 表或视图不存在
SQL> connect fttest/fttest
已连接。
SQL> alter table test1 move tablespace ftitem10g;
表已更改。
SQL> select table_name,tablespace_name from user_tables where table_name='TEST1';
TABLE_NAME TABLESPACE_NAME
------------------------------ ------------------------------
TEST1 FTITEM10G
SQL> select index_name,table_name from user_indexes where table_name='TEST1';
INDEX_NAME TABLE_NAME
------------------------------ ------------------------------
PK_TEST1 TEST1
IDX1 TEST1
SQL> alter index PK_TEST1 rebuild;
索引已更改。
SQL> alter index IDX1 rebuild;
索引已更改。
但为什么我查询其表所属的表空间已经变成FTITEM10G了,可我在pl/SQL来查看表仍在FTEST表空间中呢而没有在FTITEM10G表空间中,望大家指点,我初学
-
likaiabc
发布于2008-05-21 11:10:16
-
谢谢
-
yuxuan
发布于2008-05-21 12:32:14
-
谢谢分享
-
foxmile
发布于2008-05-21 14:02:04
-
咋没见西瓜自己整这么个玩意。
标题搜索
日历
|
|||||||||
| 日 | 一 | 二 | 三 | 四 | 五 | 六 | |||
| 1 | 2 | 3 | 4 | ||||||
| 5 | 6 | 7 | 8 | 9 | 10 | 11 | |||
| 12 | 13 | 14 | 15 | 16 | 17 | 18 | |||
| 19 | 20 | 21 | 22 | 23 | 24 | 25 | |||
| 26 | 27 | 28 | 29 | 30 | 31 | ||||
我的存档
数据统计
- 访问量: 368
- 日志数: 30
- 建立时间: 2008-04-04
- 更新时间: 2008-04-04
