Zu Hauptinhalt springen Zu ergänzendem Inhalt springen

FirstSortedValue - Diagrammfunktion

FirstSortedValue() gibt den Wert der in value festgelegten Formel zurück, der dem Ergebnis der Sortierung des sort_weight-Arguments entspricht, z. B. der Name des Produkts mit dem niedrigsten Preis pro Einheit. Der n-te-Wert in der Sortierreihenfolge kann in rank festgelegt werden. Weist mehr als ein Ergebnis dasselbe Feld sort_weight für die festgelegte Funktion rank auf, gibt die Funktion NULL zurück.

Syntax:  

FirstSortedValue([{SetExpression}] [DISTINCT] [TOTAL [<fld {,fld}>]] value, sort_weight [,rank])

Rückgabe Datentyp: dual

Argumente:  

Argumente
Argument Beschreibung
value Ausgabefeld. Die Funktion findet den Wert der Formel value, der dem Ergebnis der Sortierung von sort_weight entspricht.
sort_weight

Eingabefeld. Die Formel mit den Daten, die sortiert werden sollen. Der erste (niedrigste) Wert von sort_weight wird gefunden, aus dem der entsprechende Wert der Formel value bestimmt wird. Wenn Sie ein Minuszeichen vor sort_weight voranstellen, liefert die Funktion stattdessen den letzten (höchsten) sortierten Wert.

rank

Durch rank "n" größer 1 wird der n-te Wert ausgegeben.

SetExpression Standardmäßig berechnet sich die Aggregierungsfunktion über alle wählbaren Werte. Alternativ können Sie die der Berechnung zugrunde liegenden Werte über die Auswahlformel bestimmen.
DISTINCT Der Zusatz DISTINCT vor den Funktionsargumenten bewirkt, dass bei der Auswertung der Funktionsargumente entstehende Duplikate nicht berücksichtigt werden.
TOTAL

Der Zusatz TOTAL vor der Funktion bewirkt, dass die Berechnung über alle ausgewählten bzw. wählbaren Werte erfolgt, und nicht nur über diejenigen, die zu dem Wert der aktuellen Dimension zählen. Die Dimensionen des Diagramms werden also nicht berücksichtigt.

Mit TOTAL [<fld {.fld}>], wobei auf den Zusatz TOTAL eine Liste aus mindestens einem Feldnamen (d. h. einer Teilmenge der Diagrammdimensionsvariablen) folgt, erstellen Sie eine Teilmenge aller möglichen Werte.

Definieren des Aggregierungsbereichs

Beispiele und Ergebnisse:  

Daten
CustomerProductUnitSalesUnitPrice
AstridaAA416
AstridaAA1015
AstridaBB99
BetacabBB510
BetacabCC220
BetacabDD-25
CanutilityAA815
CanutilityCC-19
Beispiele und Ergebnisse
BeispielErgebnis
firstsortedvalue (Product, UnitPrice)

BB, das Product mit dem niedrigsten UnitPrice (9).

firstsortedvalue (Product, UnitPrice, 2)

BB, das Product mit dem zweitniedrigsten UnitPrice (10).

firstsortedvalue (Customer, -UnitPrice, 2)

Betacab, der Customer mit dem Product, das den zweithöchsten UnitPrice (20) hat.

firstsortedvalue (Customer, UnitPrice, 3)

NULL, denn es gibt zwei Werte von Customer (Astrida und Canutility) mit demselben rank (drittniedrigsten) UnitPrice (15).

Verwenden Sie den Qualifizierer distinct, um sicherzustellen, dass keine unerwarteten NULL-Ergebnisse auftreten.

firstsortedvalue (Customer, -UnitPrice*UnitSales, 2)

Canutility, der Customer mit dem zweithöchsten Bestellwert: UnitPrice multipliziert mit UnitSales (120).

In Beispielen verwendete Daten:

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

Canutility|AA|8|15

Canutility|CC||19

] (delimiter is '|');

Hat diese Seite Ihnen geholfen?

Wenn Sie ein Problem mit dieser Seite oder ihrem Inhalt feststellen, sei es ein Tippfehler, ein ausgelassener Schritt oder ein technischer Fehler, informieren Sie uns bitte!