sql >> Database >  >> RDS >> Oracle

Hoe u aggregatiegegevens op n-niveau het beste kunt berekenen op basis van gegevens op (n-1)-niveau (Oracle)

Dankzij het MODEL syntaxisfunctie hint van GregV op het Oracle-forum Ik zou deze vraag echt heel kort en nauwkeurig kunnen schrijven zonder de noodzaak van porno . Cool!

Dus om gemakkelijk het verschil te zien met mijn voorbeeldcode en een minimaal 10g Oracle db hoeft u alleen het originele script dat hierboven is gelinkt op de volgende manier aan te passen:

        /**************************
         * the original sample query base data
         ***************************/
        ...  -- all content before the last select of the original example-SQL

        /**************************
         * the original sample porno-query
         ***************************/

        ,agg_porno as (
            select
                descr,

                ...  -- all the porno-query details

            from sum_data_lvl1
            /*
             DESCR                              SUM        AGG_LVL SUM_ID
             ---------------------------------- ---------- ------- ------
             money available in 2013            33233235.3       1 MA
             money spent in 2013                 4253235.3       1 MS
             money bound to contracts in 2013     34333500       1 MB
             money spent 2013 in % of available         12       2 MSP
             money bound 2013 in % of available        103       2 MBP
            */
        )

        /**************************
         * the new nice model-based query instead
         ***************************/

        ,agg_model as (
            select
                descr,
                trunc(s,1) as sum,
                agg_lvl,
                sum_id 
            from sum_data_lvl1
            model
                dimension by (sum_id)
                measures (descr, sum as s, agg_lvl)
                rules (
                    s['MSP'] = s['MS'] / s['MA'] * 100,
                    s['MBP'] = s['MB'] / s['MA'] * 100
                )
        )
        /*
         DESCR                              SUM        AGG_LVL SUM_ID
         ---------------------------------- ---------- ------- ------
         money available in 2013            33233235.3       1 MA
         money spent in 2013                 4253235.3       1 MS
         money bound to contracts in 2013     34333500       1 MB
         money spent 2013 in % of available       12.7       2 MSP
         money bound 2013 in % of available      103.3       2 MBP
         */

select * from agg_porno where 1=0  -- change to 1=1 to see these results
union all select * from agg_model where 1=1  -- change to 1=0 to hide these results



  1. Voer een wiskundige uitdrukking uit en stel de waarde in op variabele in SQL

  2. Update de eerste rij mysql php

  3. standaard datumnotatie wijzigen laravel sql-query

  4. Hoe moet ik een tabelnaam doorgeven aan een opgeslagen proces?