Database Growth report

 Use this query to find future database growth projection.



--Output 


Database   Create     Database   Used    Used    Free    Free                    Previous   Previous   Current    Current    Previous   Previous   Current    Current

Name       Time       Size       Space   in %    Space   in %    Week    Week in Month      Month in % Month      Month in % Year       Year in %  Year %     Year in %

---------- ---------- ---------- ------- ------- ------- ------- ------- ------- ---------- ---------- ---------- ---------- ---------- ---------- ---------- ----------


set longchunksize 500;
set pagesize 1000;
set lines 2000;
set linesize 500;
Col database_name format a10 heading 'Database|Name'
Col create_time format a10 heading 'Create|Time'
Col database_size format a10 heading 'Database|Size'
Col used_space format a7 heading 'Used|Space'
Col used_in format a7 heading 'Used|in %'
Col free_space format a7 heading 'Free|Space'
Col free_in format a7 heading 'Free|in %'
Col growth_week format a7 heading 'Week'
Col growth_week_in format a7 heading 'Week in %'
Col growth_current_month format a10 heading 'Current|Month'
Col growth_current_month_in format a10 heading 'Current|Month in %'
Col growth_previous_month format a10 heading 'Previous|Month'
Col growth_previous_month_in format a10 heading 'Previous|Month in %'
COl growth_previous_year format a10 heading 'Previous|Year'
Col growth_previous_year_in format a10 heading 'Previous|Year in %'
Col growth_current_year format a10 heading 'Current|Year %'
Col growth_current_year_in format a10 heading 'Current|Year in %'
SELECT *
FROM   (SELECT (SELECT name
                FROM   v$database) Database_Name,
               (SELECT Min(creation_time)
                FROM   v$datafile) Create_Time,
               Round(( SUM(USED.bytes) / 1024 / 1024 / 1024 ), 2)
               || ' GB'            Database_Size,
               Round(( SUM(USED.bytes) / 1024 / 1024 / 1024 ) - Round(
                     FREE.p / 1024 / 1024 / 1024), 2)
               || ' GB'            Used_Space,
               Round(( ( SUM(USED.bytes) / 1024 / 1024 / 1024 ) -
                       ( FREE.p / 1024 / 1024 / 1024 ) ) /
                           Round(SUM(USED.bytes) / 1024 / 1024 / 1024, 2) * 100,
               2)
               || '% GB'           Used_in,
               Round(( FREE.p / 1024 / 1024 / 1024 ), 2)
               || ' GB'            Free_Space,
               Round(( ( SUM(USED.bytes) / 1024 / 1024 / 1024 ) - ( (
                             SUM(USED.bytes) / 1024 / 1024 / 1024 ) - Round(
                             FREE.p / 1024 / 1024 / 1024)
                                                                          ) ) /
                     Round(
                           SUM(USED.bytes) / 1024 / 1024 / 1024, 2) * 100, 2)
               || '% GB'           Free_in,
               Round(( ( SUM(USED.bytes) / 1024 / 1024 / 1024 ) -
                       ( FREE.p / 1024 / 1024 / 1024 ) ) /
                           (SELECT SYSDATE - Min(creation_time)
                           FROM   v$datafile) * 7, 2)
               || ' GB'            Growth_WEEK,
               Round(( ( ( SUM(USED.bytes) / 1024 / 1024 / 1024 ) - (
                         FREE.p / 1024 / 1024 / 1024 ) )
                             /
                               (SELECT SYSDATE - Min(creation_time)
                               FROM   v$datafile) / Round((
                       SUM(USED.bytes) / 1024 / 1024 / 1024 ), 2
                                                    ) * 100 ) * 7, 3)
               || '% GB'           Growth_WEEK_in,
               Round(( ( SUM(USED.bytes) / 1024 / 1024 / 1024 ) -
                       ( FREE.p / 1024 / 1024 / 1024 ) ) /
                           (SELECT SYSDATE - Min(creation_time)
                           FROM   v$datafile) * (SELECT
                     To_char(Add_months(SYSDATE, -1), 'dd')
                                                 FROM   dual), 2)
               || ' GB'            Growth_Previous_Month,
               Round(( ( ( SUM(USED.bytes) / 1024 / 1024 / 1024 ) - (
                         FREE.p / 1024 / 1024 / 1024 ) )
                             /
                               (SELECT SYSDATE - Min(creation_time)
                               FROM   v$datafile) / Round((
                       SUM(USED.bytes) / 1024 / 1024 / 1024 ), 2
                                                    ) * 100 ) * (SELECT
                     To_char(
                     Add_months(SYSDATE, -1)
                     ,
                     'dd')
                                                                 FROM   dual), 3
               )
               || '% GB'           Growth_Previous_Month_in,
               Round(( ( SUM(USED.bytes) / 1024 / 1024 / 1024 ) -
                       ( FREE.p / 1024 / 1024 / 1024 ) ) /
                           (SELECT SYSDATE - Min(creation_time)
                           FROM   v$datafile) * (SELECT To_char(SYSDATE, 'dd')
                                                 FROM   dual), 2)
               || ' GB'            Growth_Current_Month,
               Round(( ( ( SUM(USED.bytes) / 1024 / 1024 / 1024 ) - (
                         FREE.p / 1024 / 1024 / 1024 ) )
                             /
                               (SELECT SYSDATE - Min(creation_time)
                               FROM   v$datafile) / Round((
                       SUM(USED.bytes) / 1024 / 1024 / 1024 ), 2
                                                    ) * 100 ) * (SELECT
                     To_char(SYSDATE, 'dd')
                                                                 FROM   dual), 3
               )
               || '% GB'           Growth_Current_Month_in,
               Round(( ( SUM(USED.bytes) / 1024 / 1024 / 1024 ) -
                       ( FREE.p / 1024 / 1024 / 1024 ) ) /
                           (SELECT SYSDATE - Min(creation_time)
                           FROM   v$datafile) * (SELECT Trunc(SYSDATE, 'YYYY') -
                                                        Add_months(Trunc(SYSDATE
                                                                   ,
                                                                   'YYYY'), -12)
                                                 FROM   dual), 2)
               || ' GB'            Growth_Previous_Year,
               Round(( ( ( SUM(USED.bytes) / 1024 / 1024 / 1024 ) - (
                         FREE.p / 1024 / 1024 / 1024 ) )
                             /
                               (SELECT SYSDATE - Min(creation_time)
                               FROM   v$datafile) / Round((
                       SUM(USED.bytes) / 1024 / 1024 / 1024 ), 2
                                                    ) * 100 ) * (SELECT
                     Trunc(SYSDATE, 'YYYY') - Add_months(Trunc(SYSDATE, 'YYYY'),
                                              -12)
                                                                 FROM   dual), 3
               )
               || '% GB'           Growth_Previous_Year_in,
               Round(( ( SUM(USED.bytes) / 1024 / 1024 / 1024 ) -
                       ( FREE.p / 1024 / 1024 / 1024 ) ) /
                           (SELECT SYSDATE - Min(creation_time)
                           FROM   v$datafile) * (SELECT Add_months(Trunc(SYSDATE
                                                                   ,
                                                                   'YYYY'), 12)
                                                        - Trunc(SYSDATE, 'YYYY')
                                                 FROM   dual), 2)
               || ' GB'            Growth_Current_Year,
               Round(( ( ( SUM(USED.bytes) / 1024 / 1024 / 1024 ) - (
                         FREE.p / 1024 / 1024 / 1024 ) )
                             /
                               (SELECT SYSDATE - Min(creation_time)
                               FROM   v$datafile) / Round((
                       SUM(USED.bytes) / 1024 / 1024 / 1024 ), 2
                                                    ) * 100 ) * (SELECT
                     Add_months(Trunc(SYSDATE, 'YYYY'), 12) -
                     Trunc(SYSDATE, 'YYYY')
                        FROM   dual), 3)
               || '% GB'           Growth_Current_Year_in
        FROM   (SELECT bytes
                FROM   v$datafile
                UNION ALL
                SELECT bytes
                FROM   v$tempfile
                UNION ALL
                SELECT bytes
                FROM   v$log) used,
               (SELECT SUM(bytes) AS P
                FROM   dba_free_space) free
        GROUP  BY free.p); 


------Without spaces----


set longchunksize 500;

set pagesize 1000;

set lines 2000;

set linesize 500;

Col Database_Name format a10 HEADING 'Database|Name'

Col Create_Time format a10 HEADING 'Create|Time'

Col Database_Size format a10 HEADING 'Database|Size'

Col Used_Space format a7 HEADING 'Used|Space'

Col Used_in format a7 HEADING 'Used|in %'

Col Free_Space format a7 HEADING 'Free|Space'

Col Free_in format a7 HEADING 'Free|in %'

Col Growth_WEEK format a7 HEADING 'Week'

Col Growth_WEEK_in format a7 HEADING 'Week in %'

Col Growth_Current_Month format a10 HEADING 'Current|Month'

Col Growth_Current_Month_in format a10 HEADING 'Current|Month in %'

Col Growth_Previous_Month format a10 HEADING 'Previous|Month'

Col Growth_Previous_Month_in format a10 HEADING 'Previous|Month in %'

COl Growth_Previous_Year format a10 HEADING 'Previous|Year'

Col Growth_Previous_Year_in format a10 HEADING 'Previous|Year in %'

Col Growth_Current_Year format a10 HEADING 'Current|Year %'

Col Growth_Current_Year_in format a10 HEADING 'Current|Year in %'


select * from (select

(select name from v$database) Database_Name,(select min(creation_time) from v$datafile) Create_Time,

ROUND((SUM(USED.BYTES) / 1024 / 1024/1024 ),2) || ' GB' Database_Size,

ROUND((SUM(USED.BYTES) / 1024 / 1024/1024 ) - ROUND(FREE.P / 1024 / 1024/1024 ),2) || ' GB' Used_Space,

ROUND(((SUM(USED.BYTES) / 1024 / 1024/1024 ) - (FREE.P / 1024 / 1024/1024 )) / ROUND(SUM(USED.BYTES) / 1024 / 1024/1024 ,2)*100,2) || '% GB' Used_in,

ROUND((FREE.P / 1024 / 1024/1024 ),2) || ' GB' Free_Space,

ROUND(((SUM(USED.BYTES) / 1024 / 1024/1024 ) - ((SUM(USED.BYTES) / 1024 / 1024/1024 ) - ROUND(FREE.P / 1024 / 1024/1024 )))/ROUND(SUM(USED.BYTES) / 1024 / 1024/1024,2 )*100,2) || '% GB' Free_in,

ROUND(((SUM(USED.BYTES) / 1024 / 1024/1024 ) - (FREE.P / 1024 / 1024/1024 ))/(select sysdate-min(creation_time) from v$datafile)*7,2) || ' GB' Growth_WEEK,

ROUND((((SUM(USED.BYTES) / 1024 / 1024/1024 ) - (FREE.P / 1024 / 1024/1024 ))/(select sysdate-min(creation_time) from v$datafile)/ROUND((SUM(USED.BYTES) / 1024 / 1024/1024 ),2)*100)*7,3) || '% GB' Growth_WEEK_in,

ROUND(((SUM(USED.BYTES) / 1024 / 1024/1024 ) - (FREE.P / 1024 / 1024/1024 ))/(select sysdate-min(creation_time) from v$datafile)*(select to_char(add_months(sysdate,-1),'dd') from dual),2) || ' GB' Growth_Previous_Month,

ROUND((((SUM(USED.BYTES) / 1024 / 1024/1024 ) - (FREE.P / 1024 / 1024/1024 ))/(select sysdate-min(creation_time) from v$datafile)/ROUND((SUM(USED.BYTES) / 1024 / 1024/1024 ),2)*100)*(select to_char( add_months(sysdate,-1),'dd') from dual),3) || '% GB' Growth_Previous_Month_in,

ROUND(((SUM(USED.BYTES) / 1024 / 1024/1024 ) - (FREE.P / 1024 / 1024/1024 ))/(select sysdate-min(creation_time) from v$datafile)*(select to_char(sysdate,'dd') from dual),2) || ' GB' Growth_Current_Month,

ROUND((((SUM(USED.BYTES) / 1024 / 1024/1024 ) - (FREE.P / 1024 / 1024/1024 ))/(select sysdate-min(creation_time) from v$datafile)/ROUND((SUM(USED.BYTES) / 1024 / 1024/1024 ),2)*100)*(select to_char(sysdate,'dd') from dual),3) || '% GB' Growth_Current_Month_in,

ROUND(((SUM(USED.BYTES) / 1024 / 1024/1024 ) - (FREE.P / 1024 / 1024/1024 ))/(select sysdate-min(creation_time) from v$datafile)*(select trunc(sysdate,'YYYY')-add_months(trunc(sysdate,'YYYY'),-12)  from dual),2) || ' GB' Growth_Previous_Year,

ROUND((((SUM(USED.BYTES) / 1024 / 1024/1024 ) - (FREE.P / 1024 / 1024/1024 ))/(select sysdate-min(creation_time) from v$datafile)/ROUND((SUM(USED.BYTES) / 1024 / 1024/1024 ),2)*100)*(select trunc(sysdate,'YYYY')-add_months(trunc(sysdate,'YYYY'),-12)  from dual),3) || '% GB' Growth_Previous_Year_in,

ROUND(((SUM(USED.BYTES) / 1024 / 1024/1024 ) - (FREE.P / 1024 / 1024/1024 ))/(select sysdate-min(creation_time) from v$datafile)*(select add_months(trunc(sysdate,'YYYY'),12)-trunc(sysdate,'YYYY') from dual),2) || ' GB' Growth_Current_Year,

ROUND((((SUM(USED.BYTES) / 1024 / 1024/1024 ) - (FREE.P / 1024 / 1024/1024 ))/(select sysdate-min(creation_time) from v$datafile)/ROUND((SUM(USED.BYTES) / 1024 / 1024/1024 ),2)*100)*(select add_months(trunc(sysdate,'YYYY'),12)-trunc(sysdate,'YYYY') from dual),3) || '% GB' Growth_Current_Year_in

from (

SELECT BYTES FROM V$DATAFILE  UNION ALL

SELECT BYTES FROM V$TEMPFILE  UNION ALL

SELECT BYTES FROM V$LOG) used,(SELECT SUM(BYTES) AS P FROM DBA_FREE_SPACE) free group by free.p);

Comments

Popular posts from this blog

Oracle 12c : How To Purge The UNIFIED AUDIT TRAIL

Oracle 11g: Install Instant Client 11.2.0.3.0 on Linux x86_64 Server.

gDBClone Powerful Database Clone/Snapshot Management Tool (Doc ID 2099214.1)