题解 | #查找描述信息中包含robot的电影对应的分类名称以及电影数目,而且还需要该分类对应电影数量>=5部#

一定要好好审题!!分为三个步骤
(找到含有‘robot’的电影所属的类别,这些类别构成集合A)
(这一步与‘robot’无关,找出包含的电影数量>=5的所有类别,这些类别构成集合B)
(集合A与集合B做交集,得到集合C,再查出集合C中的每个类别包含几个‘robot’的电影)

  1. 找到包含‘robot’的电影id,再根据这些电影id找到这些电影属于哪些电影类别,这些类别构成集合A。这一步包含在t1表中。

    (select f.film_id, fc.category_id from film f 
    join film_category fc on f.film_id=fc.film_id 
    where f.description like '%robot%' or '%robot' or 'robot%') t1
  2. 找出集合B。先将类别id与类别名对应起来,这一步包含在t2表中。

    (select fc.film_id, fc.category_id,c.name from category c
    join film_category fc on c.category_id=fc.category_id
    ) t2

    再将t2表提炼,得到包含电影总数(不管是不是‘robot’)大于等于5的类别,这就是集合B。这一步包含在t3表中。

    (select t2.category_id, t2.name,count(t2.film_id) from 
    (select fc.film_id, fc.category_id,c.name from category c
    join film_category fc on c.category_id=fc.category_id
    ) t2
    group by t2.category_id,t2.name
    having count(t2.film_id)>=5
    ) t3
  3. 最后将集合A与集合B做交集,得到集合C,也就是t1表和t3表做连接,查一下集合C里每一个类别拥有多少个‘robot’电影,就OK了。

    (以下是完整代码)

select t3.name,count(t1.film_id) from
(select f.film_id, fc.category_id from film f 
join film_category fc on f.film_id=fc.film_id 
where f.description like '%robot%' or '%robot' or 'robot%') t1
join
(select t2.category_id, t2.name,count(t2.film_id) from 
(select fc.film_id, fc.category_id,c.name from category c
join film_category fc on c.category_id=fc.category_id
) t2
group by t2.category_id,t2.name
having count(t2.film_id)>=5
) t3
on t1.category_id=t3.category_id
group by t3.name;
全部评论

相关推荐

点赞 评论 收藏
转发
头像
不愿透露姓名的神秘牛友
04-29 12:10
点赞 评论 收藏
转发
点赞 收藏 评论
分享
牛客网
牛客企业服务