Only - funzione per grafici
Only() restituisce un valore se esiste esclusivamente un unico risultato possibile dai dati aggregati. Ad esempio, la ricerca dell'unico prodotto con prezzo unitario = 9 restituirà NULL se più di un prodotto ha un prezzo unitario di 9.
Sintassi:
Only([{SetExpression}] [TOTAL [<fld {,fld}>]] expr)
Tipo di dati restituiti: duale
Argomenti:
| Argomento | Descrizione |
|---|---|
| expr | L'espressione o il campo contenente i dati da misurare. |
| SetExpression | Per impostazione predefinita, la funzione di aggregazione aggrega la serie di possibili record definiti dalla selezione. È possibile definire una serie di record alternativa mediante un'espressione Set Analysis. |
| TOTAL |
Se la parola TOTAL viene riportata prima degli argomenti della funzione, il calcolo verrà effettuato su tutti i valori possibili dati dalle selezioni correnti e non solo su quelli relativi al valore dimensionale attuale, vale a dire che verranno ignorate le dimensioni del grafico. Utilizzando TOTAL [<fld {.fld}>], dove il qualificatore TOTAL è seguito da un elenco di uno o più nomi di campo come sottogruppo delle variabili di dimensione del grafico, si crea un sottogruppo di tutti i valori possibili. |
Esempi e risultati:
| 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 |
| Esempi | Risultati |
|---|---|
|
Only({<UnitPrice={9}>} Product) |
BB, perché è l'unico Product che ha un UnitPrice di '9'. |
|
Only({<Product={DD}>} Customer) |
Betacab, perché si tratta del solo Customer a vendere un Product denominato 'DD'. |
|
Only({<UnitPrice={20}>} UnitSales) |
Il numero di UnitSales in cui UnitPrice è 20 è 2, perché esiste un solo valore di UnitSales dove UnitPrice =20. |
|
Only({<UnitPrice={15}>} UnitSales) |
NULL, perché sono presenti due valori di UnitSales dove UnitPrice =15. |
Dati utilizzati negli esempi:
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 '|');