表:Candidate
+-----+---------+
| id | Name |
+-----+---------+
| 1 | A |
| 2 | B |
| 3 | C |
| 4 | D |
| 5 | E |
+-----+---------+
表:Vote
+-----+--------------+
| id | CandidateId |
+-----+--------------+
| 1 | 2 |
| 2 | 4 |
| 3 | 3 |
| 4 | 2 |
| 5 | 5 |
+-----+--------------+
id 是自动递增的主键,
CandidateId 是 Candidate 表中的 id.
请编写 sql 语句来找到当选者的名字,上面的例子将返回当选者B
+------+
| Name |
+------+
| B |
+------+
注意: 你可以假设没有平局,换言之,最多只有一位当选者
题目来源:力扣(LeetCode)
题目链接:https://leetcode-cn.com/problems/winning-candidate
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处
select name
from
(select name,
count(*) as v_num
from vote t1 inner join candidate t2
on candidateid=t2.id group by candidateid order by v_num desc) temp
limit 1;
使用内连接将两表连接起来,根据候选人编号分组,计算每个候选人的票数,再降序排序,取第一个值即为票数最高的候选人。
知识点
:连接查询、分组、排序、子查询