周末作了一天的Partitioned Table旧有资料的归档。
主要是用Partitioned Table的Exchange功能。
基本步骤:
1. 构造能用来做exchange的table A。
2. 进行exchange
3. 将segments从物理上转移到归档用的tablespace.
4. Drop 被exchange出的Partition
5. 被drop 的Partition的Tablespace—〉drop
6. Rebuild A中被mark unusable的Index.
Exchange是Partitioned Table 技术中一个非常有用的功能,尤其是当需要将旧资料进行归档的时侯。
Exchange的限制:
Range-Hashßà hash
Range-Listßà List
Range/HASH/LIST ßànon-partitioned table
.. .. ..
以上是9i administrator guides 归类出来的,简而言之,就是Partitioned Table中要用来做exchange的Partition的类型必须和所交换的Table(Partition)一致。
所以在第一步构造用来做exchange的Table的时侯,类型的一致很重要。
比如,如果是Range-Hash Partitioned table要把一个Range Partition exchange出来,那用来交换的Table必须和这个Range Partition 类型一致。
也就是说这个Table必须是Hash Partitioned Table.
进行Exchange的语法:
Illustrate:
alter table Part_table exchange partition Part_0710
with table Part_arch0710
including indexes without validation update global indexes;
几个重点
1. Including indexes: 表明将Local indexes 一同exchange出来。此选项需要用来与之exchange的table 有建立一样的Index.
2. Without validation: with validation是验证是否rows被正确的Mapping. Without validation则是跳过此验证,在这种情况下,exchange 只做data dictionary的更新(这也是exchange快的原因,因为它根本上只是在data dictionary里将segments的归属作了变更)。这里有一个例外,如果在exchange中的table有PK或者unique constraint,是会强制作with validation,不管有没有指定without validation,这样做是为了保证constraint的完整性。如果要避免这个问题,可以在exchange之前先disable相关的constraint,在完成后再enable。
3. Update global indexes:使用此选项可避免Partitioned table的global index在exchange后被mark unusable。用这种方式在功能上不会影响到正常业务,但其过程中产生的额外loading会对业务性能的表现产生影响。如果不使用此选项,则必须在exchange后对global index进行rebuild。不过这个选项只会update被exchange出Partition的table的global index。如上的例子,表A的global index是不会被update,所以如果接下来exchange出的Partition的资料还要用的话,依然需要rebuild,但这已经不影响正常业务。
4. Drop 被exchange出来的Partition所在的Tablespace之前,注意把segments从物理上移动到归档Table A所在的Tablespace。上文提到了exchange只是在data dictionary里对segments的归属作了改变。
5. Exchange后,空的Partition可以直接DROP,无须带update global index。