Del via


Bruk variabler til å forbedre DAX formler

Som datamodellerer kan det være utfordrende å skrive og feilsøke noen DAX beregninger. Det er vanlig at komplekse beregningskrav ofte innebærer å skrive sammensatte eller komplekse uttrykk. Sammensatte uttrykk kan innebære bruk av mange nestede funksjoner, og muligens gjenbruk av uttrykkslogikk.

Bruk av variabler i DAX formler kan hjelpe deg med å skrive mer komplekse og effektive beregninger. Variabler kan forbedre ytelsen, påliteligheten, lesbarheten og redusere kompleksiteten.

I denne artikkelen skal vi demonstrere de tre første fordelene ved å bruke et eksempelmål for salgsvekst fra år til år (YoY). (Formelen for Salgsvekst i År er periodesalg, minus salg for samme periode i fjor, dividert med salg for samme periode i fjor.)

La oss starte med følgende måldefinisjon.

Sales YoY Growth % =
DIVIDE(
    ([Sales] - CALCULATE([Sales], PARALLELPERIOD('Date'[Date], -12, MONTH))),
    CALCULATE([Sales], PARALLELPERIOD('Date'[Date], -12, MONTH))
)

Målet gir riktig resultat, men la oss nå se hvordan det kan forbedres.

Forbedre ytelsen

Legg merke til at formelen gjentar uttrykket som beregner «samme periode i fjor». Denne formelen er ineffektiv, da den krever at Power BI evaluerer det samme uttrykket to ganger. Måldefinisjonen kan gjøres mer effektiv ved hjelp av en variabel, VAR.

Følgende måldefinisjon representerer en forbedring. Den bruker et uttrykk til å tilordne resultatet «samme periode i fjor» til en variabel med navnet SalesPriorYear. Variabelen brukes deretter to ganger i RETURN-uttrykket.

Sales YoY Growth % =
VAR SalesPriorYear =
    CALCULATE([Sales], PARALLELPERIOD('Date'[Date], -12, MONTH))
RETURN
    DIVIDE(([Sales] - SalesPriorYear), SalesPriorYear)

Målet fortsetter å produsere det riktige resultatet, og gjør det i omtrent halvparten av spørringstiden.

Forbedre lesbarheten

Legg merke til hvordan valget av variabelnavn gjør RETUR-uttrykket enklere å forstå i den forrige måldefinisjonen. Uttrykket er kort og selvbeskrivende.

Forenkle feilsøking

Variabler kan også hjelpe deg med å feilsøke en formel. Hvis du vil teste et uttrykk som er tilordnet en variabel, skriver du om RETURN-uttrykket midlertidig for å sende variabelen.

Følgende måldefinisjon returnerer bare variabelen SalesPriorYear. Legg merke til hvordan det kommenterer det tiltenkte RETURN-uttrykket. Med denne teknikken kan du enkelt tilbakestille den når feilsøkingen er fullført.

Sales YoY Growth % =
VAR SalesPriorYear =
    CALCULATE([Sales], PARALLELPERIOD('Date'[Date], -12, MONTH))
RETURN
    --DIVIDE(([Sales] - SalesPriorYear), SalesPriorYear)
    SalesPriorYear

Reduser kompleksiteten

I tidligere versjoner av DAXstøttes ikke variabler ennå. Komplekse uttrykk som introduserte nye filterkontekster, måtte bruke funksjonene EARLIER eller EARLIESTDAX til å referere til ytre filterkontekster. Dessverre fant datamodellerere disse funksjonene vanskelige å forstå og bruke.

Variabler evalueres alltid utenfor filtrene som RETURN-uttrykket gjelder for. Av denne grunn, når du bruker en variabel i en endret filterkontekst, oppnår den det samme resultatet som EARLIEST-funksjonen. Bruk av funksjonene EARLIER eller EARLIEST kan derfor unngås. Det betyr at du nå kan skrive formler som er mindre komplekse, og som er enklere å forstå.

Vurder følgende beregnede kolonnedefinisjon lagt til i tabellen underkategori. Den evaluerer en rangering for hver produktunderkategori basert på kolonneverdiene underkategorisalg.

Subcategory Sales Rank =
COUNTROWS(
    FILTER(
        Subcategory,
        EARLIER(Subcategory[Subcategory Sales]) < Subcategory[Subcategory Sales]
    )
) + 1

Funksjonen EARLIER brukes til å referere til kolonneverdieni gjeldende radkontekst.

Den beregnede kolonnedefinisjonen kan forbedres ved hjelp av en variabel i stedet for EARLIER-funksjonen. Variabelen CurrentSubcategorySales lagrer kolonneverdien kolonneverdi i gjeldende radkontekst, og RETURN-uttrykket bruker den i en endret filterkontekst.

Subcategory Sales Rank =
VAR CurrentSubcategorySales = Subcategory[Subcategory Sales]
RETURN
    COUNTROWS(
        FILTER(
            Subcategory,
            CurrentSubcategorySales < Subcategory[Subcategory Sales]
        )
    ) + 1