VAR
Slaat het resultaat van een expressie op als een benoemde variabele, die vervolgens als argument kan worden doorgegeven aan andere metingexpressies. Zodra resulterende waarden zijn berekend voor een variabeleexpressie, worden deze waarden niet gewijzigd, zelfs niet als naar de variabele wordt verwezen in een andere expressie.
Syntaxis
VAR <name> = <expression>
Parameters
Term | Definitie |
---|---|
name |
De naam van de variabele (id). Scheidingstekens worden niet ondersteund. 'varName' of [varName] resulteert bijvoorbeeld in een fout. Ondersteunde tekenset: a-z, A-Z, 0-9. 0-9 is niet geldig als eerste teken. __ (dubbel onderstrepingsteken) is toegestaan als voorvoegsel voor de id-naam. Er worden geen andere speciale tekens ondersteund. Gereserveerde trefwoorden zijn niet toegestaan. Namen van bestaande tabellen zijn niet toegestaan. Lege ruimten zijn niet toegestaan. |
expression |
Een DAX-expressie die een scalaire waarde of tabelwaarde retourneert. |
Retourwaarde
Een benoemde variabele die het resultaat van het expressieargument bevat.
Opmerkingen
Een expressie die als argument aan VAR wordt doorgegeven, kan een andere VAR declaratie bevatten.
Wanneer u naar een variabele verwijst:
- Metingen kunnen niet verwijzen naar variabelen die buiten de metingexpressie zijn gedefinieerd, maar kunnen verwijzen naar functionele bereikvariabelen die zijn gedefinieerd in de expressie.
- Variabelen kunnen verwijzen naar metingen.
- Variabelen kunnen verwijzen naar eerder gedefinieerde variabelen.
- Er kan niet naar kolommen in tabelvariabelen worden verwezen via de syntaxis TableName[ColumnName].
Zie VARvoor aanbevolen procedures bij het gebruik van DAX.
Zie VARvoor meer informatie over hoe DAX wordt gebruikt in een DAX Query.
Voorbeeld
Als u een percentage van de groei per jaar wilt berekenen zonder een variabele te gebruiken, kunt u drie afzonderlijke metingen maken. Met deze eerste meting wordt de som van de verkoophoeveelheid berekend:
Sum of SalesAmount = SUM(SalesTable[SalesAmount])
Met een tweede meting wordt het verkoopbedrag voor het vorige jaar berekend:
SalesAmount PreviousYear =
CALCULATE([Sum of SalesAmount],
SAMEPERIODLASTYEAR(Calendar[Date])
)
Vervolgens kunt u een derde meting maken die de andere twee metingen combineert om een groeipercentage te berekenen. U ziet dat de meting Sum of SalesAmount op twee plaatsen wordt gebruikt; eerst om te bepalen of er een verkoop is, vervolgens opnieuw om een percentage te berekenen.
Sum of SalesAmount YoY%: =
IF([Sum of SalesAmount] ,
DIVIDE(([Sum of SalesAmount] – [SalesAmount PreviousYear]), [Sum of SalesAmount])
)
Met behulp van een variabele kunt u één meting maken waarmee hetzelfde resultaat wordt berekend:
YoY% =
VAR Sales =
SUM(SalesTable[SalesAmount])
VAR SalesLastYear =
CALCULATE ( SUM ( SalesTable[SalesAmount] ), SAMEPERIODLASTYEAR ( 'Calendar'[Date] ) )
return if(Sales, DIVIDE(Sales – SalesLastYear, Sales))
Met behulp van een variabele kunt u hetzelfde resultaat krijgen, maar op een beter leesbare manier. En omdat het resultaat van de expressie is opgeslagen in de variabele, kunnen de prestaties van de meting aanzienlijk worden verbeterd omdat deze niet telkens opnieuw hoeft te worden berekend wanneer deze wordt gebruikt.
Verwante inhoud
Variabelen gebruiken om uw DAX formules te verbeterenDAX query's