1050. 合作过至少三次的演员和导演
ActorDirector 表:
±------------±--------+
| Column Name | Type |
±------------±--------+
| actor_id | int |
| director_id | int |
| timestamp | int |
±------------±--------+
timestamp 是这张表的主键(具有唯一值的列).
编写解决方案找出合作过至少三次的演员和导演的 id 对 (actor_id, director_id)
示例 1:
输入:
ActorDirector 表:
±------------±------------±------------+
| actor_id | director_id | timestamp |
±------------±------------±------------+
| 1 | 1 | 0 |
| 1 | 1 | 1 |
| 1 | 1 | 2 |
| 1 | 2 | 3 |
| 1 | 2 | 4 |
| 2 | 1 | 5 |
| 2 | 1 | 6 |
±------------±------------±------------+
输出:
±------------±------------+
| actor_id | director_id |
±------------±------------+
| 1 | 1 |
±------------±------------+
解释:
唯一的 id 对是 (1, 1),他们恰好合作了 3 次。
题解
找出合作过至少三次的演员和导演的 id 对 (actor_id, director_id)
- 也就是说,把它俩当做一个整体,计数超过3次的即可
方法一 group by + having
select
actor_id,director_id
from ActorDirector group by actor_id,director_id having count(1)>=3
方法二 row_number
with tmp as (
select
actor_id,director_id,row_number() over(partition by actor_id,director_id ) as rn
from ActorDirector
)
select distinct actor_id,director_id from tmp where rn>=3