Two new analytic functions LEAD and LAG are introduced in SQL Server 2012. LEAD is used to find the next row value and LAG is used to find the previous row value.
USE [AdventureWorks]
GO
-- Create tbl_temp Table
CREATE TABLE [dbo].[tbl_temp](
[code] [int] NOT NULL,
[type] [nvarchar](50) NOT NULL,
[quantity] [int] NOT NULL
)
GO
-- Insert records in the table
INSERT [dbo].[tbl_temp] ([code], [type], [quantity]) VALUES (1, N'Radio', 17)
GO
INSERT [dbo].[tbl_temp] ([code], [type], [quantity]) VALUES (2, N'Mobile', 22)
GO
INSERT [dbo].[tbl_temp] ([code], [type], [quantity]) VALUES (3, N'TV', 31)
GO
INSERT [dbo].[tbl_temp] ([code], [type], [quantity]) VALUES (4, N'Watch', 42)
GO
INSERT [dbo].[tbl_temp] ([code], [type], [quantity]) VALUES (5, N'DVD', 55)
GO
INSERT [dbo].[tbl_temp] ([code], [type], [quantity]) VALUES (6, N'CD', 90)
GO
-- See records from the table
SELECT * FROM tbl_temp
-- LEAD and LAG value
data:image/s3,"s3://crabby-images/b6077/b607750f601a8883900d48859772117fd98214f6" alt="lag and lead functions in sql server 2012 lag and lead in sql server 2012"
SELECT *, LEAD(quantity) OVER(ORDER BY quantity) AS LeadValue,
LAG(quantity) OVER(ORDER BY quantity) AS LagValue
FROM tbl_temp
data:image/s3,"s3://crabby-images/bda39/bda39b27e8fc22c74d0bd719504546984c7505b1" alt="analytic functions in sql server 2012 lead and lag sql server lead lag functions"
data:image/s3,"s3://crabby-images/dd174/dd174c3b08f23ee8d6f73a813629416fd1d153da" alt="new analytic functions lead and lag in sql server 2012 lead and lag in sql server 2012"
-- LEAD and LAG with offset 2
SELECT *, LEAD(quantity,2) OVER(ORDER BY quantity) AS LeadValue,
LAG(quantity,2) OVER(ORDER BY quantity) AS LagValue
FROM tbl_temp
data:image/s3,"s3://crabby-images/8f715/8f715beda614031a7520cd4c111eb134c0048771" alt="lag and lead functions with offset 2 lead and lag with offset 2"
data:image/s3,"s3://crabby-images/21105/21105774d493f52909d9d6849c21f3955889ae21" alt="lag() and lead() functions in sql server 2012 lead() and lag() functions"