scripts/collector/oracle/sql/extracts/statspack/awrhistosstat.sql (85 lines of code) (raw):

-- -- Copyright 2024 Google LLC -- -- Licensed under the Apache License, Version 2.0 (the "License"). -- you may not use this file except in compliance with the License. -- You may obtain a copy of the License at -- -- https://www.apache.org/licenses/LICENSE-2.0 -- -- Unless required by applicable law or agreed to in writing, software -- distributed under the License is distributed on an "AS IS" BASIS, -- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. -- See the License for the specific language governing permissions and -- limitations under the License. -- spool &outputdir/opdb__awrhistosstat__&v_tag prompt PKEY|DBID|INSTANCE_NUMBER|HH|STAT_NAME|HH24_TOTAL_SECS|CUMULATIVE_VALUE|AVG_VALUE|MODE_VALUE|MEDIAN_VALUE|PERC50|PERC75|PERC90|PERC95|PERC100|MIN_VALUE|MAX_VALUE|SUM_VALUE|COUNT|DMA_SOURCE_ID|DMA_MANUAL_ID WITH v_osstat_all AS (SELECT os.dbid, os.instance_number, TO_CHAR(os.SNAP_TIME, 'hh24') hh24, os.stat_name, os.value cumulative_value, os.delta_value, ( (os.snap_time) - LAG((os.snap_time)) OVER (PARTITION BY os.dbid, os.instance_number, os.stat_name ORDER BY os.snap_id)) * 60 * 60 * 24 as snap_total_secs, PERCENTILE_CONT(0.5) within GROUP (ORDER BY os.delta_value DESC) over ( PARTITION BY os.dbid, os.instance_number, TO_CHAR(os.SNAP_TIME, 'hh24'), os.stat_name) AS "PERC50", PERCENTILE_CONT(0.25) within GROUP (ORDER BY os.delta_value DESC) over ( PARTITION BY os.dbid, os.instance_number, TO_CHAR(os.SNAP_TIME, 'hh24'), os.stat_name) AS "PERC75", PERCENTILE_CONT(0.1) within GROUP (ORDER BY os.delta_value DESC) over ( PARTITION BY os.dbid, os.instance_number, TO_CHAR(os.SNAP_TIME, 'hh24'), os.stat_name) AS "PERC90", PERCENTILE_CONT(0.05) within GROUP (ORDER BY os.delta_value DESC) over ( PARTITION BY os.dbid, os.instance_number, TO_CHAR(os.SNAP_TIME, 'hh24'), os.stat_name) AS "PERC95", PERCENTILE_CONT(0) within GROUP (ORDER BY os.delta_value DESC) over ( PARTITION BY os.dbid, os.instance_number, TO_CHAR(os.SNAP_TIME, 'hh24'), os.stat_name) AS "PERC100" FROM (SELECT snap.SNAP_TIME, s.*, osname.STAT_NAME, NVL(DECODE(GREATEST(value, NVL(LAG(value) OVER ( PARTITION BY s.dbid, s.instance_number, osname.STAT_NAME ORDER BY s.snap_id), 0)), value, value - LAG(value) OVER ( PARTITION BY s.dbid, s.instance_number, osname.STAT_NAME ORDER BY s.snap_id), 0), 0) AS delta_value FROM STATS$OSSTAT s inner join STATS$SNAPSHOT snap ON s.snap_id = snap.snap_id AND s.instance_number = snap.instance_number AND s.dbid = snap.dbid inner join STATS$OSSTATNAME osname ON s.osstat_id = osname.osstat_id WHERE snap.snap_time BETWEEN (SELECT max(snap_time) FROM STATS$SNAPSHOT WHERE snap_time < '&&v_min_snaptime' ) AND '&&v_max_snaptime' AND s.dbid = '&&v_dbid') os ) , vossummary AS ( SELECT :v_pkey AS pkey, dbid, instance_number, hh24, stat_name, ROUND(SUM(snap_total_secs)) hh24_total_secs, ROUND(AVG(cumulative_value)) cumulative_value, ROUND(AVG(delta_value)) avg_value, ROUND(STATS_MODE(delta_value)) mode_value, ROUND(MEDIAN(delta_value)) median_value, ROUND(AVG(perc50)) PERC50, ROUND(AVG(perc75)) PERC75, ROUND(AVG(perc90)) PERC90, ROUND(AVG(perc95)) PERC95, ROUND(AVG(perc100)) PERC100, ROUND(MIN(delta_value)) min_value, ROUND(MAX(delta_value)) max_value, ROUND(SUM(delta_value)) sum_value, COUNT(1) count FROM v_osstat_all GROUP BY :v_pkey, dbid, instance_number, hh24, stat_name) SELECT pkey, dbid, instance_number, hh24, stat_name, hh24_total_secs , cumulative_value, avg_value, mode_value, median_value, PERC50, PERC75, PERC90, PERC95, PERC100, min_value, max_value, sum_value, count, :v_dma_source_id AS DMA_SOURCE_ID, :v_manual_unique_id AS DMA_MANUAL_ID FROM vossummary; spool off