Test your Oracle Partition Archive/Restore Strategies:
Test your Oracle Partition Archive/Restore Strategies:
Are we testing our Oracle Partitioned Tables Restore strategies?
Your Partition Archives are no good if they cannot be restored when needed and if your SLA’s require you to restore the partition if needed by the customer.
Below are some quick steps you can follow to test your Oracle Partitioning Archive and Restore Strategy.
Step1
The first thing to do is create a discrete table that is identical to the partition we want to remove. It must have the same columns, data types, constraints and indexes, and exist in the same tablespace as the partition. The index must also exist in the corresponding index tablespace.
create table PNAME
Step2
The new table in Step1contains no rows, and the index is empty. When we EXCHANGE a partition with a discrete table, we literally exchange data segments between the two. That's why they must match in structure and location. No data is actually moved, only internal pointers are changed.
ALTER TABLE TABLE_NAME
WITH TABLE PNAME
Check the indexes at this step – you will see that indexes of only the partition you exchanged got UNUSABLE (the partition you exchanged is the partition you want to drop)
Please Note: Both Global Index and Local Indexes for that partition may be unusable.
A Global Index rebuild will affect the entire table and a Local index rebuild will affect only the Local partition.
Step3:
Count the rows in the new table and in the partitioned table before and after the EXCHANGE to convince yourself that the data did actually "move", check the size of the data segments, and the status of the indexes.
SELECT COUNT(*) FROM
SELECT COUNT(*) FROM PNAME
Step4:
We no longer need the old partition as it is now empty, so we can drop it.
ALTER TABLE TABLE_NAME
If the goal was to simply transport this partition without removing it, we could exchange the table back into the partition after transporting the tablespace.
To get ready make the tablespaces we are transporting (data and index) READ ONLY to ensure there are no active transactions, and that none start during transport. The rest of the partitions are unaffected.
ALTER TABLESPACE PNAME
Use the DBMS_TTS utility to verify the tablespace set is self contained. That is, there are no objects within the set that reference (foreign key, constraint indexes, etc) any object outside of the set. The set can be one or more tablespaces that will be transported together.
EXECUTE sys.DBMS_TTS.TRANSPORT_SET_CHECK(‘PNAME
SELECT * FROM sys.TRANSPORT_SET_VIOLATIONS;
exp \'sys/sysdba as sysdba\' file= PNAME
Make sure the unix team backs up the dump file
Drop table PNAME
Alter tablespace PNAME
Drop tablespace PNAME
Restore the Archived Partition
Step1:
Import the dump file into the target system. Again this is fast because we only import data definitions; the data already exists in the named datafiles. imp USERID='xxxxxx' TRANSPORT_TABLESPACE=y DATAFILES='xxxxxxxxxxxxxxxxx' TABLESPACES=
FILE= PNAME
Step2:
By default the new tablespaces will be READ ONLY. In order to create the table partition and EXCHANGE it with the existing discrete table we will have to make them READ WRITE.
ALTER TABLESPACE PNAME
Step3:
We now have a partitioned table with one empty partition, and our discrete table with data that was transported. To complete the process, simply EXCHANGE data segments between the empty partition and discrete table. Then, count the number of rows, check the size of data segments and status of indexes again.
ALTER TABLE TABLE_NAME
WITH TABLE PNAME
After the exchange check the indexes again – you may to rebuild the Local Index after this step if the indexes are unusable.
When you are convinced the exchange has occurred properly and the partitioned table is functional, drop the now empty discrete table and you are done for this year.
DROP TABLE PNAME