Overview:
- If you try to resize/shrink a datafile before Oracle Database 23ai, you’ll get “ORA-03297: file contains used data beyond requested RESIZE value” because there are segments’ extents (your tables, indexes, partitions, etc.) that are blocking it from shrinking
- Oracle 23ai database introduces the option to shrink a Bigfile tablespace to reclaim the datafile’s free space
- A new procedure (SHRINK_TABLESPACE) has been added to the DBMS_SPACE package to shrink tablespace and reclaim the data file’s free space.
In this blog, I’ll demonstrate the steps to shrink a tablespace.
Prerequisites:
Preparation Steps:
1. Create a new Bigfile Tablespace
– Connect to a pluggable database and create a new tablespace
data:image/s3,"s3://crabby-images/3a81f/3a81f856a586e49b25b98795be2bbd2cdfa25c44" alt="oracle oracle"
data:image/s3,"s3://crabby-images/e6e13/e6e13793a3ddac37b409baa122ae414fd81993b5" alt="oracle2 oracle2"
2. Create new tables on the new tablespace and populate them with data
– In my example, I used the below commands to create and populate tables with data
– Create tables:
create table segments tablespace TEST_SHRINK as select * from dba_segments;
create table objects tablespace TEST_SHRINK as select * from dba_objects;
create table my_tables tablespace TEST_SHRINK as select * from dba_tables;
– Populate tables by running below inserts multiple times:
insert into segments select * from segments;
insert into objects select * from objects;
insert into my_tables select * from my_tables;
– Check the datafile’s free space and write it down for comparison later
data:image/s3,"s3://crabby-images/43326/43326f63996d7feb88a3c3a4d6c55de851f7413e" alt="oracle3 oracle3"
3. Delete some data or truncate table/s.
– In my example, I truncated the OBJECTS table.
– Notice that the datafile’s free space increased from 316M to 724 M
data:image/s3,"s3://crabby-images/ecd7f/ecd7fe4f344e3608bec88fefddae9762a73441b9" alt="oracle4 oracle4"
Shrink Tablespace Steps:
1. Analyze a tablespace shrink by executing the below command
execute dbms_space.shrink_tablespace('TEST_SHRINK',shrink_mode => DBMS_SPACE.TS_MODE_ANALYZE)
– It is highly recommended to determine the potential of a shrink operation by running it in analyze mode first
– The result of this analysis contains useful information including a list of unsupported objects, a list of movable objects, the total size of movable objects in the tablespace, and the suggested target size for the tablespace
– Analyzing a tablespace will take much less time than actually shrinking it
data:image/s3,"s3://crabby-images/2d306/2d3065f3d20ff83def86f0f1675d97b700b3cb70" alt="oracle5 oracle5"
2. Execute shrink tablespace by executing the below command
execute dbms_space.shrink_tablespace('TEST_SHRINK')
– Notice that the datafile’s size was shrunk from 1024M to 202M and the datafile’s free space was decreased from 724M to 7M
data:image/s3,"s3://crabby-images/2a77d/2a77d04c3a2af024656cbc7ab8c6471690f8d28e" alt="oracle6 oracle6"
data:image/s3,"s3://crabby-images/e3c14/e3c14e0ec04f39bea20027537cc98c29e3a67b55" alt="oracle7 oracle7"