Aggr - diagramfunktion

Aggr() returnerar en uppsättning värden för uttrycket beräknade över den angivna dimensionen eller de angivna dimensionerna. Exempelvis det maximala värdet av försäljningen, per kund, per region. Funktionen Aggr används för avancerade aggregeringar där Aggr-funktionen omsluts av en annan aggregeringsfunktion och uppsättningen med resultat från Aggr-funktionen används som indata till den aggregering som den är kapslad i.

Syntax:  

Aggr({SetExpression}[DISTINCT] [NODISTINCT ] expr, StructuredParameter{, StructuredParameter})

Datatyp som returneras: dual

Argument:  

Argument Beskrivning
expr

Ett uttryck som består av en aggregeringsfunktion. Som standard kommer aggregeringsfunktionen att aggregera över den uppsättning möjliga poster som definierats av urvalet.

StructuredParameter

StructuredParameter består av en dimension och om du väljer det, sorteringskriterier i formatet: (Dimension(Sort-type, Ordering))

Dimensionen är ett enda fält och kan inte vara ett uttryck. Dimensionen används för att avgöra värdematrisen som uttrycket Aggr är beräknat för.

Om sorteringskriterier tas med sorteras värdematrisen som skapas av funktionen Aggr för dimensionen. Detta är viktigt när sorteringsordningen påverkar resultatet av uttrycket som funktionen Aggr är inkapslad i.

Mer information om hur sorteringskriterier kan användas finns i Lägga till sorteringskriterier till dimensionen i den strukturerade parametern.

SetExpression Som standard kommer aggregeringsfunktionen att aggregera över den uppsättning möjliga poster som definierats av urvalet. En alternativ uppsättning poster kan definieras med ett uttryck för set-analys.
DISTINCT Om uttrycksargumentet föregås av kvalificeraren distinct, eller om ingen kvalificerare alls används, kommer varje distinkt kombination av dimensionsvärden endast att generera ett returvärde. Det är normalt så här aggregeringar skapas - varje distinkt kombination av dimensionsvärden ger en rad i diagrammet.
NODISTINCT

Om uttrycksargumentet föregås av kvalificeraren nodistinct kan varje kombination av dimensionsvärden generera mer än ett returvärde beroende på den underliggande datastrukturen. Om det bara finns en dimension, returnerar funktionen aggr en uppsättning med samma antal element som det finns rader i källdata.

Grundläggande aggregeringsfunktioner, som Sum, Min och Avg, returnerar ett enda numeriskt värde. Funktionen Aggr() kan däremot jämföras med att skapa en tillfällig resultatuppsättning (en virtuell tabell) som en annan aggregering kan utföras över. Genom att till exempel beräkna ett medelvärde för försäljning genom att lägga ihop försäljningen efter kund i en Aggr()-sats och sedan beräkna medelvärdet för det hoplagda resultatet: Avg(TOTAL Aggr(Sum(Sales), Customer)).

Tips: Använd Aggr()-funktionen i beräknade dimensioner om du vill skapa kapslade diagramaggregeringar på flera nivåer.

Begränsningar:  

Varje dimension i en Aggr()-funktion måste vara ett enda fält. Den får inte vara ett uttryck (beräknad dimension).

Lägga till sorteringskriterier till dimensionen i den strukturerade parametern

I sin grundläggande form är argumentet StructuredParameter i Aggr -funktionssyntaxen en enda dimension. Uttrycket: Aggr(Sum(Sales, Month)) hittar det totala värdet av försäljningen för varje månad. Emellertid kan oväntade resultat uppstå om sorteringskriterier inte används om det omsluts av en annan aggregeringsfunktion. Detta beror på att vissa dimensioner kan sorteras numeriskt eller alfabetiskt och så vidare.

I StructuredParameter-argumentet i Aggr-funktionen kan du ange sorteringskriterier för dimensionen i ditt uttryck. På så sätt tillämpar du en sorteringsordning på den virtuella tabellen som produceras av Aggr-funktionen.

Argumentet StructuredParameter har följande syntax:

(FieldName, (Sort-type, Ordering))

Strukturerade parametrar kan vara kapslade:

(FieldName, (FieldName2, (Sort-type, Ordering)))

Sorteringstyp kan vara: NUMERIC, TEXT, FREQUENCY eller LOAD_ORDER.

Ordningstyperna som är associerade med varje sorteringstyp är följande:

Sorteringstyp Tillåtna ordningstyper
NUMERIC ASCENDING, DESCENDING eller REVERSE
TEXT ASCENDING, A2Z, DESCENDING, REVERSE eller Z2A
FREQUENCY DESCENDING, REVERSE eller ASCENDING
LOAD_ORDER ASCENDING, ORIGINAL, DESCENDING eller REVERSE

Ordningstyperna REVERSE och DESCENDING är likvärdiga.

För sorteringstypen TEXT är ordningstyperna ASCENDING och A2Z likvärdiga, och DESCENDING, REVERSE och Z2A också likvärdiga.

För sorteringstypen LOAD_ORDER är ordningstyperna ASCENDING och ORIGINAL likvärdiga.

Exempel och resultat:  

Exempel Resultat
Avg(Aggr(Sum(UnitSales*UnitPrice), Customer))

Uttrycket Aggr(Sum(UnitSales*UnitPrice), Customer) hittar det totala värdet av försäljningen efter Customer och returnerar en värdematris: 295, 715 och 120 för de treCustomer-värdena

I praktiken har vi byggt en tillfällig lista med värden utan att ha behövt skapa en explicit tabell eller kolumn som innehåller de värdena.

Dessa värden används som indata iAvg()-funktionen för att beräkna medelvärdet för försäljning, 376,6667. (Du måste ha Totalvärden valt under Presentation i egenskapspanelen.

Aggr(NODISTINCT Max(UnitPrice), Customer)

En värdematris: 16, 16, 16, 25, 25, 25, 19 och 19. Kvalificeraren nodistinct innebär att matrisen innehåller ett element för varje rad i källdata: varje är maximalt UnitPrice för varje Customer och Product.

max(aggr(sum(Customers)-above(Sum(Customers)), (MonthYear,(NUMERIC, ASCENDING))))

Använda sorteringskriterier i StructuredParameter-argumentet i uttrycket:max(aggr(sum(Customers)-above(Sum(Customers)), (MonthYear,(NUMERIC, ASCENDING))))

Utan sorteringskriterier beror resultatet av uttrycket max(aggr(sum(Customers)-above(Sum(Customers)), (MonthYear))) på hur dimensionen MonthYear är sorterad. Vi kanske då inte får det resultat vi vill ha.

Genom att lägga till värden för sorteringstyp och ordningstyp för dimensionen ger vi sorteringskriterier till den strukturerade parametern: (MonthYear, (NUMERIC, ASCENDING)), där sorteringstypen NUMERIC och ordningen ASCENDING bestämmer att MonthYear sorteras i stigande numerisk ordning.

Här vill vi hitta den största ökningen i antal kunder månad för månad. Detta skulle till exempel kunna användas i en KPI-visualisering.

Aggr-delen av uttrycket jämför totalt antal kunder under en månad (angivet av MonthYear) med totalt antal kunder under föregående månad.

Genom att använda sorteringskriterier med dimensionen: (MonthYear,(NUMERIC, ASCENDING)) är vi säkra på att Aggr jämför antal kunder i månader efter varandra i den virtuella tabellen genom att sortera månaderna i stigande numerisk ordning, och inte i stigande alfabetisk ordning.

Data som används i exempel:

Skapa en tabell med Customer, Product, UnitPrice och UnitSales som dimensioner. Lägg till uttrycket i tabellen som ett mått.

ProductData:

LOAD * inline [

Customer|Product|UnitSales|UnitPrice

Astrida|AA|4|16

Astrida|AA|10|15

Astrida|BB|9|9

Betacab|BB|5|10

Betacab|CC|2|20

Betacab|DD|25|25

Canutility|AA|8|15

Canutility|CC||19

] (delimiter is '|');

Hjälpte den här informationen?

Tack för att du berättar det här. Är det något du vill säga om det här avsnittet?

Varför var informationen inte till hjälp och hur kan vi förbättra den?