rank dense_rank
时间: 2023-10-15 21:05:25 浏览: 93
这两个都是窗口函数中的排名函数,主要用于排序后对行进行编号。不同之处在于当值相同时,rank 会跳过相等的值,而 dense_rank 则不会跳过。
具体来说,假设有如下表格:
| id | score |
|----|-------|
| 1 | 90 |
| 2 | 80 |
| 3 | 90 |
| 4 | 70 |
使用 `rank()` 函数后,会得到以下结果:
| id | score | rank |
|----|-------|------|
| 1 | 90 | 1 |
| 2 | 80 | 2 |
| 3 | 90 | 1 |
| 4 | 70 | 4 |
可以看到,在第一、三行中,分数相等,因此它们的 rank 都是 1;而在第二行中,因为前面已经有一个分数比它高的行,因此它的 rank 是 2。注意第四行的 rank 不是 3 而是 4,这是因为排名函数默认升序排序。
使用 `dense_rank()` 函数后,会得到以下结果:
| id | score | dense_rank |
|----|-------|-----------|
| 1 | 90 | 1 |
| 2 | 80 | 2 |
| 3 | 90 | 1 |
| 4 | 70 | 3 |
可以看到,虽然第一、三行的分数相等,但 dense_rank 函数没有跳过它们,因此都是 1。另外,第四行的 dense_rank 是 3,这是因为前面有两个分数比它高的行。
阅读全文