描述
假设云音乐数据库里面现在有几张如下简化的数据表:
关注follow表,第一列是关注人的id,第二列是被关注人的id,这2列的id组成主键
user_id | follower_id |
1 | 2 |
1 | 4 |
2 | 3 |
这张表的第一行代表着用户id为1的关注着id为2的用户
这张表的第二行代表着用户id为1的关注着id为4的用户
这张表的第三行代表着用户id为2的关注着id为3的用户
个人的喜欢的音乐music_likes表,第一列是用户id,第二列是喜欢的音乐id,这2列的id组成主键
user_id | music_id |
1 | 17 |
2 | 18 |
2 | 19 |
3 | 20 |
4 | 17 |
这张表的第一行代表着用户id为1的喜欢music_id为17的音乐
....
这张表的第五行代表着用户id为4的喜欢music_id为17的音乐
音乐music表,第一列是音乐id,第二列是音乐name,id是主键
id | music_name |
17 | yueyawang |
18 | kong |
19 | MOM |
20 | Sold Out |
请你编写一个SQL,查询向user_id = 1 的用户,推荐其关注的人喜欢的音乐。
不要推荐该用户已经喜欢的音乐,并且按music的id升序排列。你返回的结果中不应当包含重复项
上面的查询结果如下:
music_name |
kong |
MOM |
题解:
1、查询user_id = 1 的用户,其关注的人(follower_id )
select follower_id from follow where user_id = 1
2、查询user_id = 1 的用户,其关注的人喜欢的音乐 (music_id)
select music_id from music_likes
where user_id in (select follower_id from follow where user_id = 1);
3、查询user_id = 1 的用户,其关注的人喜欢的音乐,同时排除该用户已经喜欢的音乐(music_id)
select music_id from music_likes
where user_id in (select follower_id from follow where user_id = 1)
and music_id not in (select music_id from music_likes where user_id = 1);
4、接着,连接表music,获得音乐name,并且按music的id升序排列,返回的结果不包含重复项。
注意:order by的字段必须要出现在select中
select music_name
from(
select distinct music_name,m.id
from (
select music_id from music_likes
where user_id in (select follower_id from follow where user_id = 1)
and music_id not in (select music_id from music_likes where user_id = 1)
) a
join music m on a.music_id = m.id
order by id
)t