天天看點

資料庫SQL實戰 --26.查找描述資訊中包括robot的電影對應的分類名稱以及電影數目,而且還需要該分類對應電影數量大于5部

題目描述

查找描述資訊中包括robot的電影對應的分類名稱以及電影數目,而且還需要該分類對應電影數量>=5部
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));

CREATE TABLE category  (
category_id  tinyint(3)  NOT NULL ,
name  varchar(25) NOT NULL, `last_update` timestamp,
PRIMARY KEY ( category_id ));

CREATE TABLE film_category  (
film_id  smallint(5)  NOT NULL,
category_id  tinyint(3)  NOT NULL, `last_update` timestamp);
           

解決思路

SELECT c.name, COUNT(fc.film_id) FROM
 (select category_id, COUNT(film_id) AS category_num FROM
     film_category  GROUP BY category_id HAVING count(film_id)>=5) AS cc,
 film AS f, film_category AS fc, category AS c
WHERE  f.description LIKE '%robot%'
AND f.film_id = fc.film_id
AND c.category_id = fc.category_id
AND c.category_id=cc.category_id
           
  • 找到對應電影數量>=5的所有分類,建立成虛表cc:

    (select category_id, count(film_id) as category_num from film_category group by category_id having count(film_id)>=5) as cc

  • 設定限制條件 f.description like ‘%robot%’
  • 在表cc、f、fc、c中查找包括robot的電影對應的分類名稱和對應的電影數目。

繼續閱讀