Gå till huvudinnehåll Gå till ytterligare innehåll

Above

Above() utvärderar ett uttryck på en rad ovanför den aktuella raden inom ett kolumnsegment i en tabell. Vilken rad som den beräknas för beror på värdet för offset, om sådant finns, standardvärdet är raden direkt ovanför. För diagram som inte är tabeller utvärderar Above() för raden ovanför den aktuella raden i diagrammets raka tabellmotsvarighet.

Syntax:  

Above([TOTAL] expr [ , offset [,count]])

Returnerad datatyp: dual

Argument:  

  • expr: Det uttryck eller fält som innehåller de data som ska mätas.
  • offset: Om en offset n större än 0 anges, flyttas utvärderingen av uttrycket n antal rader ovanför den aktuella raden. Om startpunkt anges till 0 utvärderas uttrycket på den aktuella raden. Anges ett negativt värde för startpunkten gör det att Above-funktionen fungerar likadant som Below-funktionen med motsvarande positivt värde för startpunkten.
  • count: Om ett tredje uttryck,count, anges till större än 1, returnerar funktionen ett intervall av count-värden, ett för varje count-tabellrad. Raderna räknas uppåt från den ursprungliga cellen. I denna form kan funktionen användas som argument i någon av de speciella intervallfunktionerna. Intervallfunktioner
  • TOTAL: Om tabellen är endimensionell eller om kvalificeraren iTOTAL används som argument, motsvarar det aktuella kolumnsegmentet alltid hela kolumnen.

    Definiera aggregeringens omfattning

På kolumnsegmentets första rad returneras värdet NULL, eftersom det inte finns någon rad ovanför denna.

Anteckning om informationEtt kolumnsegment definieras som en konsekutiv underuppsättning med celler som har samma värden för dimensionerna i den aktuella sorteringsordningen. Postöverskridande diagramfunktioner beräknas i kolumnsegmentet exklusive dimensionen längst till höger i motsvarande raka tabelldiagram. Om det enbart finns en dimension i diagrammet, eller om kvalificeraren TOTAL anges, utvärderas uttrycket över en hel tabell.
Anteckning om informationOm tabellen eller diagrammets tabellmotsvarighet har flera vertikala dimensioner, inbegriper det aktuella kolumnsegmentet endast rader som har samma värden som den aktuella raden i samtliga dimensionskolumner, utom den kolumn som visar den sista dimensionen i fältens inbördes sorteringsordning.

Begränsningar:  

  • Rekursiva anrop returnerar NULL.

  • Sortering på y-värden i diagram, eller sortering efter uttryckskolumner i tabeller, är inte tillåtet när denna diagramfunktion används i något av diagrammets uttryck. Dessa sorteringsalternativ är därför automatiskt inaktiverade. När du använder den här diagramfunktion i en visualisering eller tabell kommer sorteringen av visualiseringen att återgå till den sorterade inmatningen av den här funktionen.

Exempel och resultat:  

Exempel 1:  

Exempel tabellutdata
Customer Sum(Sales) Above(Sum(Sales)) Sum(Sales) + Above(Sum(Sales)) Above offset 3 Higher?
- 2566 - - - -
Astrida587----
Betacab5395871126--
Canutility6835391222-Higher
Divadip75768314401344Higher

I återgivningen av det tabelldiagram som visas i det här exemplet skapas tabellen från dimensionen Customer och måtten: Sum(Sales) och Above(Sum(Sales)).

Kolumnen Above(Sum(Sales)) returnerar NULL för Customer-raden Astrida, eftersom det inte finns någon rad ovanför. Resultatet för raden Betacab visar värdet för Sum(Sales) för Astrida, resultatet för Canutility visar värdet för Sum(Sales) för Betacab och så vidare.

För kolumnen med etiketten Sum(Sales)+Above(Sum(Sales)) visar raden för Betacab resultatet av att Sum(Sales)-värdena lades till för raderna Betacab + Astrida (539+587). Resultatet för raden Betacab visar resultatet då Sum(Sales)-värden har lagts till för Canutility + Canutility (683+539).

Måttet med etiketten Above offset 3 som skapades med uttrycket Sum(Sales)+Above(Sum(Sales), 3) har argumentet offset, angivet som 3. Effekten blir att värdet hämtas i raden tre rader ovanför den aktuella raden. Det lägger till Sum(Sales)-värdet för aktuell Customer på värdet för Customer tre rader högre upp. Värdena som returneras för de första tre Customer-raderna är null.

Tabellen visar även mer komplexa mått: ett skapat utifrån Sum(Sales)+Above(Sum(Sales)) och ett med etiketten Higher?, som skapas utifrån IF(Sum(Sales)>Above(Sum(Sales)), 'Higher').

Anteckning om tipsFunktionen kan även användas i andra diagram, inte bara tabeller – exempelvis i stapeldiagram.
Anteckning om tipsFör andra diagramtyper omvandlar du diagrammet till den raka tabellmotsvarigheten så att du enkelt kan tolka vilken rad funktionen är relaterad till.

Exempel 2:  

I de återgivningar av tabelldiagrammen som visas i det här exemplet har fler dimensioner lagts till i diagrammen: Month och Product. För diagram med flera dimensioner beror resultatet för uttryck som innehåller funktionerna Above, Below, Top och Bottom på den ordning i vilken kolumndimensionerna sorteras av QlikView. QlikView evaluerar funktionerna baserat på de kolumnsegment som är resultatet från den dimension som kommer sist i sorteringsordningen. Sorteringsordningen för kolumner styrs under Sortera. Den motsvarar inte nödvändigtvis den ordning i vilken kolumnerna visas i en tabell.

I följande återgivning av tabelldiagrammet för exempel 2 är den sista dimensionen i sorteringsordningen Month, så Above-funktionen utvärderar utifrån månader. Det finns en serie resultat för varje Product-värde för varje månad (Jan till Aug) – ett kolumnsegment. Detta följs av en serie för nästa kolumnsegment: för varje Month för nästa Product. Det finns ett kolumnsegment för varje Customer-värde för varje Product.

Exempel tabellutdata
Customer Product Month Sum(Sales) Above(Sum(Sales))
- - - 2566 -
AstridaAAJan46-
AstridaAAFeb6046
AstridaAAMar7060
AstridaAAApr1370
AstridaAAMay7813
AstridaAAJun2078
AstridaAAJul4520
AstridaAAAug6545

Exempel 3:  

I återgivningen av tabelldiagrammet för exempel 3 är den sista dimensionen i sorteringsordningen Product. Detta görs genom att flytta dimensionen Product till läge 3 på fliken Sortering i egenskapspanelen. Funktionen Above evalueras för varje Product, och eftersom det bara finns två produkter, AA och BB, innehåller varje serie bara ett resultat som inte är null. I rad BB för månaden Jan är värdet för Above(Sum(Sales)) 46. För rad AA är värdet null. Värdet i varje AA-rad, oavsett månad, är alltid null eftersom det inte finns något värde för Product över AA. Den andra serien värderas efter AA och BB för månaden Feb, för Customer-värdet Astrida. När alla månader har utvärderats för Astrida upprepas sekvensen för nästa CustomerBetacab och så vidare.

Exempel tabellutdata
Customer Product Month Sum(Sales) Above(Sum(Sales))
- - - 2566 -
AstridaAAJan46-
AstridaBBJan4646
AstridaAAFeb60-
AstridaBBFeb6060
AstridaAAMar70-
AstridaBBMar7070
AstridaAAApr13-
AstridaBBApr1313

Exempel 4:  

Funktionen Above kan användas som indata för intervallfunktionerna. Till exempel: RangeAvg (Above(Sum(Sales),1,3)).

I argumenten för Above()-funktionen är offset inställt på 1 och count inställt på 3. Funktionen hittar resultaten av uttrycket Sum(Sales) på de tre raderna som är precis ovanför aktuell rad i kolumnsegmentet (där det finns en rad). De här tre värdena används som indata för funktionen RangeAvg() som räknar ut medelvärdet för ett angivet talintervall.

En tabell med Customer som dimension ger följande resultat för uttrycket RangeAvg().

Exempel tabellutdata
Customer RangeAvg (Above(Sum(Sales),1,3))
Astrida -
Betacab587
Canutility563
Divadip603

Data som används i exempel:

Monthnames:

LOAD * INLINE [

Month, Monthnumber

Jan, 1

Feb, 2

Mar, 3

Apr, 4

May, 5

Jun, 6

Jul, 7

Aug, 8

Sep, 9

Oct, 10

Nov, 11

Dec, 12

];

Sales2013:

crosstable (Month, Sales) LOAD * inline [

Customer|Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec

Astrida|46|60|70|13|78|20|45|65|78|12|78|22

Betacab|65|56|22|79|12|56|45|24|32|78|55|15

Canutility|77|68|34|91|24|68|57|36|44|90|67|27

Divadip|57|36|44|90|67|27|57|68|47|90|80|94

] (delimiter is '|');

För att få månaderna att sorteras i korrekt ordning när du skapar dina diagram går du till fliken Sort under diagramegenskaperna och markerar kryssrutan Expression under Sort by. Skriv Monthnumber i uttrycksrutan.

Var den här sidan till hjälp för dig?

Om du stöter på några problem med den här sidan eller innehållet på den, t.ex. ett stavfel, ett saknat steg eller ett tekniskt fel – meddela oss!

Gå med i programmet Analytics Modernization

Remove banner from view

Modernisera utan att kompromissa med dina värdefulla QlikView-appar med programmet för analysmodernisering. Klicka här för mer information eller ta kontakt: ampquestions@qlik.com