描述
film表
字段 | 说明 |
film_id | 电影id |
title | 电影名称 |
description | 电影描述信息 |
CREATE TABLE IF NOT EXISTS film (
film_id smallint(5) NOT NULL DEFAULT '0',
title varchar(255) NOT NULL,
description text,
PRIMARY KEY (film_id));
category表
字段 | 说明 |
category_id | 电影分类id |
name | 电影分类名称 |
last_update | 电影分类最后更新时间 |
CREATE TABLE category (
category_id tinyint(3) NOT NULL ,
name varchar(25) NOT NULL, `last_update` timestamp,
PRIMARY KEY ( category_id ));
film_category表
字段 | 说明 |
film_id | 电影id |
category_id | 电影分类id |
last_update | 电影id和分类id对应关系的最后更新时间 |
CREATE TABLE film_category (
film_id smallint(5) NOT NULL,
category_id tinyint(3) NOT NULL, `last_update` timestamp);
分析:
1. 先计算每个分类下电影个数,并且取出>5的分类
2. 对每个符合要求的分类下电影进行筛选,找到描述中有robot的
3. 计算数目并显示分类名称
select ca.name,tab.cnt
from(
select fc.category_id,count(fi.film_id) cnt
from film fi
join (
select fica.category_id,fica.film_id
from (
select category_id,count(film_id) count
from film_category
group by category_id
)film_count
join film_category fica
on fica.category_id = film_count.category_id
where film_count.count >= 5
)fc
on fi.film_id = fc.film_id
where fi.description like '%robot%'
group by fc.category_id
)tab
join category ca
on ca.category_id = tab.category_id
注意用having,直接join。
select ca.name,count(fi.film_id) cnt
from film fi
join film_category fc on fi.film_id = fc.film_id
join category ca on ca.category_id = fc.category_id
where fi.description like '%robot%'
and fc.category_id in (
select category_id
from film_category
group by category_id
having count(film_id) >=5
)
group by fc.category_id