Delen via


GROUPBY

Van toepassing op:berekende kolomberekende tabelMetingVisuele berekening

Notitie

Deze functie wordt afgeraden voor gebruik in visuele berekeningen omdat deze waarschijnlijk betekenisloze resultaten oplevert.

De GROUPBY-functie is vergelijkbaar met de functie SUMMARIZE. GROUPBY voert echter geen impliciete CALCULATE uit voor uitbreidingskolommen die worden toegevoegd. GROUPBY maakt het mogelijk om een nieuwe functie, CURRENTGROUP, te gebruiken in aggregatiefuncties in de extensiekolommen die worden toegevoegd. GROUPBY wordt gebruikt om meerdere aggregaties uit te voeren in één tabelscan.

Syntaxis

GROUPBY (<table> [, <groupBy_columnName> [, <groupBy_columnName> [, …]]] [, <name>, <expression> [, <name>, <expression> [, …]]])

Parameters

Term Definitie
table Elke DAX-expressie die een tabel met gegevens retourneert.
groupBy_columnName De naam van een bestaande kolom in de tabel (of in een gerelateerde tabel) waarmee de gegevens moeten worden gegroepeerd. Deze parameter kan geen expressie zijn.
name De naam die wordt gegeven aan een nieuwe kolom die wordt toegevoegd aan de lijst met GroupBy-kolommen, tussen dubbele aanhalingstekens.
expression Een van de X-aggregatiefuncties waarbij het eerste argument wordt CURRENTGROUP(). Zie de sectie Met CURRENTGROUP hieronder voor de volledige lijst met ondersteunde X-aggregatiefuncties.

Retourwaarde

Een tabel met de geselecteerde kolommen voor de groupBy_columnName argumenten en de extensiekolommen die zijn aangewezen door de naamargumenten.

Opmerkingen

  • De functie GROUPBY doet het volgende:

    1. Begin met de opgegeven tabel (en alle gerelateerde tabellen in de richting 'naar één').

    2. Maak een groepering met behulp van alle GroupBy-kolommen (die uit stap 1 moeten bestaan in de tabel).

    3. Elke groep is één rij in het resultaat, maar vertegenwoordigt een set rijen in de oorspronkelijke tabel.

    4. Evalueer voor elke groep de extensiekolommen die worden toegevoegd. In tegenstelling tot de functie SUMMARIZE wordt er geen impliciete CALCULATE uitgevoerd en wordt de groep niet in de filtercontext geplaatst.

  • Elke kolom waarvoor u een naam definieert, moet een bijbehorende expressie hebben; anders wordt er een fout geretourneerd. Het eerste argument, de naam, definieert de naam van de kolom in de resultaten. Het tweede argument, expressie, definieert de berekening die wordt uitgevoerd om de waarde voor elke rij in die kolom te verkrijgen.

  • groupBy_columnName moet zich in een tabel of in een gerelateerde tabel bevinden.

  • Elke naam moet tussen dubbele aanhalingstekens staan.

  • De functie groepeert een geselecteerde set rijen in een set samenvattingsrijen op basis van de waarden van een of meer groupBy_columnName kolommen. Er wordt één rij geretourneerd voor elke groep.

  • GROUPBY wordt voornamelijk gebruikt om aggregaties uit te voeren op tussenliggende resultaten van DAX tabelexpressies. Voor efficiënte aggregaties over fysieke tabellen in het model kunt u overwegen SUMMARIZECOLUMNS of SUMMARIZE functie te gebruiken.

  • Deze functie wordt niet ondersteund voor gebruik in de DirectQuery-modus wanneer deze wordt gebruikt in regels voor beveiliging op rijniveau (berekende kolommen of beveiliging op rijniveau).

Met CURRENTGROUP

CURRENTGROUP kan alleen worden gebruikt in een expressie waarmee een extensiekolom in de GROUPBY-functie wordt gedefinieerd. In feite retourneert CURRENTGROUP een set rijen uit het tabelargument van GROUPBY die deel uitmaken van de huidige rij van het GROUPBY resultaat. De functie CURRENTGROUP heeft geen argumenten en wordt alleen ondersteund als eerste argument voor een van de volgende aggregatiefuncties: AVERAGEX, COUNTAX, COUNTX, GEOMEANX, MAXX, MINX, PRODUCTX, STDEVX.S, STDEVX.P, SUMX, VARX.S, VARX.P.

Voorbeeld

In het volgende voorbeeld wordt eerst de totale verkoop berekend die is gegroepeerd op land en productcategorie ten opzichte van fysieke tabellen met behulp van de functie SUMMARIZECOLUMNS. Vervolgens wordt de functie GROUPBY gebruikt om het tussenliggende resultaat uit de eerste stap te scannen om de maximale verkoop in elk land in de productcategorieën te vinden.

DEFINE
VAR SalesByCountryAndCategory =
SUMMARIZECOLUMNS(
Geography[Country],
Product[Category],
"Total Sales", SUMX(Sales, Sales[Price] * Sales[Qty])
)

EVALUATE
GROUPBY(
SalesByCountryAndCategory,
Geography[Country],
"Max Sales", MAXX(CURRENTGROUP(), [Total Sales])
)

SUMMARIZE functieSUMMARIZECOLUMNS