题解 | #查找描述信息中包含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;
全部评论

相关推荐

脑袋锈住了:你这算啥,哥们中科院中强所硕士,本科211,叫我去干分拣,时薪20
点赞 评论 收藏
分享
2本硕,在这一个下午真的绷不住了,浪费了太多时间,现在的技术栈还停在C语言和stm32上,找嵌入式的实习面试被拷打,找杭州的一个也找不到,真的心里难受,linux没学过,研二了开始慌了。
一条淡水魚:嵌入式这行的面试我认为实际项目比较重要,技术栈简单的提一嘴就行,面试官在乎的关键点在于你用了这些技术做了哪些工作解决了什么问题,而不是停留在离散的那些个技术栈上,那除了教课没有意义,好比你提到的c语言和32,你用32做过哪些具体的项目?接触过什么外设?使用过哪些公司的SDK?有没有实际产品落地?以及各种只有进入真正的生产环节当中才会积累到的经验......主动去和面试官讨论这些实际的问题,甚至还能就某个具体参数的合理性与他去简单探讨一下,只要技术栈对口,基本上就稳啦~(另外linux和RTOS是嵌入式的标配哦,选一个方向走下去吧)
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务