SQL Server Last_Value() Funktion

Sql Server Last Value Funktion



Denna handledning syftar till att guida dig i att förstå funktionen last_value() i SQL Server. Funktionen låter dig hämta det sista värdet i en ordnad uppsättning värden eller en partition.

Funktionssyntax

Nedan är syntaxen för last_value-funktionen.

LAST_VALUE ( [ scalar_expression ] )  [ IGNORE NULLS | RESPECT NULLS ]
ÖVER ( [partition_efter_klausul] order_by_clause [radintervall_klausul])

Funktionsargumenten är:







  1. scalar_expression – detta definierar värdet som ska returneras. Detta kan vara en befintlig kolumn, en underfråga eller ett uttryck som återgår till ett enda värde.
  2. IGNORE NULLS – detta tillåter funktionen att ignorera nollvärden i den givna uppsättningen när det sista värdet över en partition bestäms
  3. RESPECT NULL – detta är motsatsen till IGNORE NULL-satsen. Det tvingar funktionen att beakta NULL-värden när det sista värdet över en partition bestäms.
  4. PARTITION BY – delar upp raderna för ett givet resultat i olika partitioner. Last_value-funktionen tillämpas sedan på dessa partitioner. Om partition_by-satsen saknas kommer funktionen att behandla resultatuppsättningen som en enda grupp.
  5. ORDER BY – detta bestämmer i vilken ordning raderna i en given partition följer.
  6. Rows_range – denna sats begränsar raderna i en given partition. Detta fungerar genom att ställa in ett start- och slutvärde.

Funktionen returnerar typen av det angivna skaläruttrycket.



Använda funktionen last_value över en resultatuppsättning

Anta att vi har en tabell som visas:







Vi kan tillämpa funktionen last_value() över en resultatuppsättning, som visas i exempelfrågan nedan:

Välj
SERVER NAMN,
SERVER ADRESS ,
COMPRESSION_METHOD,
STORLEK PÅ DISK,
last_value(size_on_disk) över(
ordning efter storlek_på_disk intervall mellan obegränsat föregående och obegränsat följande) största
från
INFORMATIONER E;

Resulterande värden:



Använda funktionen last_value över en partition

Vi kan också tillämpa funktionen last_value() över partitionen som visas i exemplet nedan:

Välj
SERVER NAMN,
SERVER ADRESS ,
COMPRESSION_METHOD,
STORLEK PÅ DISK,
last_value(size_on_disk) over(partition av COMPRESSION_METHOD
ordning efter storlek_på_disk intervall mellan obegränsat föregående och obegränsat följande) största
från
INFORMATIONER E;

I det här fallet grupperas data i olika partitioner baserat på komprimeringsmetoden.

Det resulterande värdet är som visas:

I tabellen ovan har vi fem partitioner, med maxvärdet i varje partition som visas i den största kolumnen.

Slutsats

I den här handledningen lärde du dig hur du använder SQL Server-funktionen last_value() för att få det sista värdet i en ordnad uppsättning eller partition.