题解 | #查找描述信息中包含robot的电影对应的分类名称以及电影数目,而且还需要该分类对应电影数量>=5部#
一定要好好审题!!分为三个步骤
(找到含有‘robot’的电影所属的类别,这些类别构成集合A)
(这一步与‘robot’无关,找出包含的电影数量>=5的所有类别,这些类别构成集合B)
(集合A与集合B做交集,得到集合C,再查出集合C中的每个类别包含几个‘robot’的电影)
找到包含‘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
找出集合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
最后将集合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;