MySQL中与ORACLE的rank()函数相当的函数是什么?

5

Oracle有两个函数——rank()和dense_rank()——我发现它们在某些应用中非常有用。我现在正在使用mysql,想知道它们是否有相当的函数?

返回结果: Oracle有两个函数——rank()和dense_rank()——我发现它们在某些应用中非常有用。我现在正在使用mysql,想知道它们是否有相当的函数?
2个回答

3

没有直接等效的方法,但你可以通过一些(不太高效的)自连接来模拟。以下是来自MySQL查询技巧集合的示例代码:

SELECT v1.name, v1.votes, COUNT(v2.votes) AS Rank
FROM votes v1
JOIN votes v2 ON v1.votes < v2.votes OR (v1.votes=v2.votes and v1.name = v2.name)
GROUP BY v1.name, v1.votes
ORDER BY v1.votes DESC, v1.name DESC;
+-------+-------+------+
| name  | votes | Rank |
+-------+-------+------+
| Green |    50 |    1 |
| Black |    40 |    2 |
| White |    20 |    3 |
| Brown |    20 |    3 |
| Jones |    15 |    5 |
| Smith |    10 |    6 |
+-------+-------+------+ 

1
我希望有更好的解决方案,但现在只能这样了。 - giroy
@younes0:如果你看白色和棕色,你会发现它(正确地)将领带排在第3名,然后跳到第5名。 - chaos
@chaos 好的,我猜跳过到第5级是oracle rank()函数的默认行为。 - younes0

1
这个 "dense_rank implement" 在 MySQL 中怎么样?
CREATE TABLE `person` (  
 `id` int(11) DEFAULT NULL,  
 `first_name` varchar(20) DEFAULT NULL,  
 `age` int(11) DEFAULT NULL,  
 `gender` char(1) DEFAULT NULL);

INSERT INTO `person` VALUES 
(1,'Bob',25,'M'),
(2,'Jane',20,'F'),
(3,'Jack',30,'M'),
(4,'Bill',32,'M'),
(5,'Nick',22,'M'),
(6,'Kathy',18,'F'),
(7,'Steve',36,'M'),
(8,'Anne',25,'F'),
(9,'Mike',25,'M');

密集排名函数之前的数据如下所示

mysql> select * from person;
+------+------------+------+--------+
| id   | first_name | age  | gender |
+------+------------+------+--------+
|    1 | Bob        |   25 | M      |
|    2 | Jane       |   20 | F      |
|    3 | Jack       |   30 | M      |
|    4 | Bill       |   32 | M      |
|    5 | Nick       |   22 | M      |
|    6 | Kathy      |   18 | F      |
|    7 | Steve      |   36 | M      |
|    8 | Anne       |   25 | F      |
|    9 | Mike       |   25 | M      |
+------+------------+------+--------+
9 rows in set (0.00 sec)

稠密排名函数(dense_rank())的输出数据如下,包括“partition by”函数。
+------------+--------+------+------+
| first_name | gender | age  | rank |
+------------+--------+------+------+
| Anne       | F      |   25 |    1 |
| Jane       | F      |   20 |    2 |
| Kathy      | F      |   18 |    3 |
| Steve      | M      |   36 |    1 |
| Bill       | M      |   32 |    2 |
| Jack       | M      |   30 |    3 |
| Mike       | M      |   25 |    4 |
| Bob        | M      |   25 |    4 |
| Nick       | M      |   22 |    6 |
+------------+--------+------+------+
9 rows in set (0.00 sec)

查询语句是:
select first_name,t1.gender,age,FIND_IN_SET(age,t1.age_set) as rank from person t2,
(select gender,group_concat(age order by age desc) as age_set from person group by gender) t1
where t1.gender=t2.gender
order by t1.gender,rank

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接