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

Data type precedence - SQL Server

       In SQL Server, data type precedence determines which data type takes precedence over others when two or more data types are combined or compared. It is important to understand data type precedence to ensure that the correct data type is used and that data is not lost or truncated during operations. In this blog, we will discuss data type precedence in SQL Server with examples. Data type precedence levels SQL Server has 16 data type precedence levels, with the highest level being 1 and the lowest level being 16. The data type with the lowest precedence is considered to be the "weakest" data type and is most likely to be converted to a higher precedence data type during operations. Here is the list of data types in SQL Server, ordered by their precedence levels: user-defined data types (highest precedence) sql_variant xml datetimeoffset datetime2 datetime smalldatetime date time float real decimal/numeric money/smallmoney bigint/i...

Synonyms, Trigger & Sequences - SQL Server

  Synonyms In SQL Server, a synonym is an alternative name for a database object, such as a table, view, stored procedure, or function. Synonyms can be useful for simplifying complex object names, abstracting the underlying object structure, or providing a layer of indirection between objects and their callers. Creating a synonym in SQL Server is straightforward. Here's an example:               CREATE SYNONYM MyTable FOR AdventureWorks2019 . dbo . MyTable ; In this example, we're creating a synonym called MyTable that points to a table called MyTable in the AdventureWorks2019 database. Now, instead of referring to the table as AdventureWorks2019.dbo.MyTable, we can simply use the synonym name MyTable. To modify a synonym in SQL Server, you can use the ALTER SYNONYM statement. Here's an example:               ALTER SYNONYM MyTable RENA...

Table Data Type- SQL Server

       In SQL Server, the table data type is a structured data type that allows you to define a table as a variable. It can be useful in scenarios where you need to store data temporarily or pass data between stored procedures or functions. In this blog, we will explore the table data type in SQL Server and provide an example of how it can be used. Introduction to the table data type The table data type is a structured data type that allows you to define a table as a variable. It can be used to store data temporarily or pass data between stored procedures or functions. The table variable behaves like a regular table in SQL Server, but it is stored in memory rather than on disk. Creating a table variable in SQL Server To create a table variable in SQL Server, you need to declare the variable and define the table structure. The following code demonstrates how to declare a table variable and define the table structure: DECLARE @MyTable TABLE (   ...