- ROW_NUMBER()
- RANK()
- DENSE_RANK()
All of these three functions are used to calculate the Id of row but in different way.
I am using the below script for examples
CREATE TABLE Marks
(
SubjectId INT,
Marks INT
)
INSERT INTO Marks VALUES(1,100),
(2,90),
(3,80),
(4,70),
(5,70),
(6,50),
(7,40),
(8,40),
(9,30)
1. ROW_NUMBER():-
This function will assign the unique Id to each row of result.
data:image/s3,"s3://crabby-images/d19e5/d19e5493963ae313b27bafab390f8ec57cb96789" alt=""
Please see the result in above image. ROW_NUMBER() has assigned unique Id to each record
2) Rank() :-
This function works in same way as ROW_NUMBER() except the "equal" records are ranked the same. This will leave the gap of between the same values. please see the below result
data:image/s3,"s3://crabby-images/87964/87964da157c046bb2b868ff58569261f81288732" alt=""
As we can see Marks with value 70 is assigned the same rank 4 but for the next value it gave rank 6 it skipped the rank 5. Same case is for value 40
3) DENSE_RANK() :-
This function is same like RANK() but it does not leave the gap when assigning the rank. it is “dense”. Please refer the below image
data:image/s3,"s3://crabby-images/a1869/a1869e0c295b9265e493b79b75d6ba5ab7a3bc73" alt=""
0 Comment(s)