Skip to main content

Analytic Functions - SQL Server

 Analytic functions in SQL Server are used to perform complex calculations on a set of data within a specific partition, and can be useful in data analysis and business intelligence applications. In this blog, we will discuss all the analytic functions available in SQL Server with examples.

ROW_NUMBER

The ROW_NUMBER function assigns a unique sequential number to each row within a partition of a result set.

Example:

SELECT ROW_NUMBER() OVER(ORDER BY Sales DESC) as SalesRank, Salesperson, Sales

FROM SalesData

 

RANK

The RANK function assigns a rank to each row within a partition of a result set, with ties receiving the same rank.

Example:

SELECT RANK() OVER(PARTITION BY Department ORDER BY Salary DESC) as DepartmentRank, Name, Salary

FROM Employee

 

DENSE_RANK

The DENSE_RANK function assigns a rank to each row within a partition of a result set, with ties receiving the same rank and no gaps in ranking.

Example:

SELECT DENSE_RANK() OVER(PARTITION BY Department ORDER BY Salary DESC) as DepartmentRank, Name, Salary

FROM Employee

 

NTILE

The NTILE function divides a result set into a specified number of groups, assigning each row a group number.

Example:

SELECT NTILE(4) OVER(ORDER BY Sales DESC) as SalesGroup, Salesperson, Sales

FROM SalesData

 

LAG

The LAG function returns the value of a column in a previous row within the same partition, with an optional offset.

Example:

SELECT Salesperson, Sales, LAG(Sales, 1) OVER(PARTITION BY Salesperson ORDER BY Date) as PreviousSales

FROM SalesData

 

LEAD

The LEAD function returns the value of a column in a subsequent row within the same partition, with an optional offset.

Example:

SELECT Salesperson, Sales, LEAD(Sales, 1) OVER(PARTITION BY Salesperson ORDER BY Date) as NextSales

FROM SalesData

 

FIRST_VALUE

The FIRST_VALUE function returns the value of the first row within a partition of a result set.

Example:

SELECT Department, Name, Salary, FIRST_VALUE(Name) OVER(PARTITION BY Department ORDER BY Salary DESC) as TopEarner

FROM Employee

 

LAST_VALUE

The LAST_VALUE function returns the value of the last row within a partition of a result set.

Example:

SELECT Department, Name, Salary, LAST_VALUE(Name) OVER(PARTITION BY Department ORDER BY Salary DESC) as LowestEarner

FROM Employee

 

SUM

The SUM function returns the sum of a column within a partition of a result set.

Example:

SELECT Department, Name, Salary, SUM(Salary) OVER(PARTITION BY Department) as DepartmentTotal

FROM Employee

 

AVG

The AVG function returns the average value of a column within a partition of a result set.

Example:

SELECT Department, Name, Salary, AVG(Salary) OVER(PARTITION BY Department) as DepartmentAverage

FROM Employee

 

MAX

The MAX function returns the maximum value of a column within a partition of a result set.

Example:

SELECT Department, Name, Salary, MAX(Salary) OVER(PARTITION BY Department) as DepartmentMax

FROM Employee

 

MIN

The MIN function returns the minimum value of a column within a partition of a result set.

Example:

SELECT Department, Name, Salary, MIN(Salary) OVER(PARTITION BY Department) as DepartmentMin

FROM Employee

 

Reference

              https://learn.microsoft.com/en-us/sql/t-sql/functions/analytic-functions-transact-sql?view=sql-server-ver16

Comments

Popular posts from this blog

SFTP Integration in SSIS package Using WinSCP DLL

  In this blog, I am planning to write about SSIS SFTP Task details and reference sites, upload and download the files from SFTP server using SSIS package with help of the winscp library. Steps to configure the winscp DLL and Download Files 1.        Please download the DLL and required files from below path https://winscp.net/eng/downloads.php#additional 2.        Once Downloaded, use the below comments to add in Local GAC "Path to the gacutil exe \gacutil.exe" /i WinSCPnet.dll 3.        Please use the below URL as guide to implement the SSIS script task to download the files from SFTP using winscp as library https://winscp.net/eng/docs/library_ssis 4.        I am just briefing the steps based on the above URL what we can try in SSIS package. 5.        Please create the below variables in SSIS package which we need ...

Geography Data Type – SQL Server

     Geography data type in SQL Server is a useful tool for storing and manipulating geographic data. It provides a set of functions and tools for working with geographical data, such as points, lines, and polygons. In this blog, we will explore the Geography data type in SQL Server with examples. Introduction to Geography data type Geography data type is a built-in data type in SQL Server that is designed to support the storage, manipulation, and analysis of geographic data. It is based on the Open Geospatial Consortium (OGC) Simple Feature Access specification, which provides a standard way to represent geographic data in a database. The Geography data type in SQL Server stores data in a geographic coordinate system, allowing you to represent points on the surface of the earth using longitude and latitude coordinates. You can also represent lines and polygons by defining a series of points that define the shape of the line or polygon. Creating a Geography data t...

XML data type Functions – SQL Server

 The XML data type in MSSQL Server is a powerful tool for handling and manipulating XML data within a relational database system. In addition to storing XML data as a column in a table, SQL Server provides a number of XML functions and methods that allow for easy parsing, querying, and transformation of XML data. In this blog post, we will cover all XML data type methods available in MSSQL Server. value() Method: The value() method is used to extract a single value from an XML instance. This method accepts an XQuery expression as a parameter, which is used to identify the value to be extracted. The syntax of the value() method is as follows: xml . value ( XQuery expression , Data type ) For example, the following query extracts the value of the 'name' element from an XML column called 'MyXMLColumn': SELECT MyXMLColumn . value ( '(/Root/Person/Name)[1]' , 'varchar(50)' ) AS Name FROM MyTable   query() Method: The query() method i...