To Estimate compression ratio:
**********************************************************************************
We can create compression using CTAS or Alter table move
After using Alter to compress tables indexes will become unusable. So rebuild them again
CREATE TABLE OI_HIGH TABLESPACE COMP COMPRESS FOR QUERY HIGH AS SELECT * FROM OE.OI;
ALTER TABLE OI_TABLE MOVE COMPRESS FOR ARCHIVE LOW;
To uncompress
ALTER TABLE EMP MOVE NOCOMPRESS;(UNTESTED)
We have 2 types of compression
Archive and DWH
DWH means Query high or Query low used in DWH.. High or low means compression rates
Archive also has high/low and it is used on tables that are not queried much.. Gives maximum storage savings
Very important document regarding Compression
http://www.oracle.com/technetwork/server-storage/sun-unified-storage/documentation/problemsolver-hcc-52014-2202692.pdf
To see what tables are compressed
SELECT table_name, compression, compress_for
FROM all_tables where compression='ENABLED';
SELECT * FROM (
SELECT
OWNER, SEGMENT_NAME, round((BYTES/1024/1024/1024),2) SIZE_GB
FROM
DBA_SEGMENTS
WHERE
SEGMENT_TYPE = 'TABLE'
ORDER BY
BYTES/1024/1024/1024 DESC ) WHERE ROWNUM <= 100 ;
select 'Alter index '||owner||'.'||INDEX_NAME||' REBUILD;' from dba_indexes where status='UNUSABLE';
ALTER TABLE HMA_PROD.PERSON MOVE COMPRESS FOR QUERY HIGH;
DECLARE l_blkcnt_cmp BINARY_INTEGER; l_blkcnt_uncmp BINARY_INTEGER; l_row_cmp BINARY_INTEGER; l_row_uncmp BINARY_INTEGER; l_cmp_ratio NUMBER; l_comptype_str VARCHAR2 (200); BEGIN DBMS_COMPRESSION.get_compression_ratio ( scratchtbsname => 'HMA_DM_SALES_DATA', ownname => 'HMA_DM_SALES', tabname => 'SLM_TH_VEHICLE_MONTHLY', partname => NULL, comptype => DBMS_COMPRESSION.comp_for_query_low, blkcnt_cmp => l_blkcnt_cmp, blkcnt_uncmp => l_blkcnt_uncmp, row_cmp => l_row_cmp, row_uncmp => l_row_uncmp, cmp_ratio => l_cmp_ratio, comptype_str => l_comptype_str ); DBMS_OUTPUT.put_line ('l_blkcnt_cmp=' || l_blkcnt_cmp); DBMS_OUTPUT.put_line ('l_blkcnt_uncmp=' || l_blkcnt_uncmp); DBMS_OUTPUT.put_line ('l_row_cmp=' || l_row_cmp); DBMS_OUTPUT.put_line ('l_row_uncmp=' || l_row_uncmp); DBMS_OUTPUT.put_line ('l_cmp_ratio=' || l_cmp_ratio); DBMS_OUTPUT.put_line ('l_comptype_str=' || l_comptype_str); END;
**********************************************************************************
We can create compression using CTAS or Alter table move
After using Alter to compress tables indexes will become unusable. So rebuild them again
CREATE TABLE OI_HIGH TABLESPACE COMP COMPRESS FOR QUERY HIGH AS SELECT * FROM OE.OI;
ALTER TABLE OI_TABLE MOVE COMPRESS FOR ARCHIVE LOW;
To uncompress
ALTER TABLE EMP MOVE NOCOMPRESS;(UNTESTED)
We have 2 types of compression
Archive and DWH
DWH means Query high or Query low used in DWH.. High or low means compression rates
Archive also has high/low and it is used on tables that are not queried much.. Gives maximum storage savings
Very important document regarding Compression
http://www.oracle.com/technetwork/server-storage/sun-unified-storage/documentation/problemsolver-hcc-52014-2202692.pdf
To see what tables are compressed
SELECT table_name, compression, compress_for
FROM all_tables where compression='ENABLED';
SELECT * FROM (
SELECT
OWNER, SEGMENT_NAME, round((BYTES/1024/1024/1024),2) SIZE_GB
FROM
DBA_SEGMENTS
WHERE
SEGMENT_TYPE = 'TABLE'
ORDER BY
BYTES/1024/1024/1024 DESC ) WHERE ROWNUM <= 100 ;
select 'Alter index '||owner||'.'||INDEX_NAME||' REBUILD;' from dba_indexes where status='UNUSABLE';
ALTER TABLE HMA_PROD.PERSON MOVE COMPRESS FOR QUERY HIGH;