Hive期末测试题(头歌)
创始人
2025-01-16 05:35:57
0

第1关:计算“Bad Boys (1995)”这部电影的评分次数

-- 使用mydb数据库 USE mydb;  -- 计算“Bad Boys (1995)”这部电影的评分次数 SELECT m.movieid, m.moviename, COUNT(r.movieid) AS rating_count FROM t_movies m JOIN t_ratings r ON m.movieid = r.movieid WHERE m.moviename LIKE '%Bad Boys (1995)%' GROUP BY m.movieid, m.moviename; 

第2关:统计每年的电影评分次数

使用Hive的字符串函数来处理这个问题。
这个查询首先从电影名称中提取出年份,然后根据年份对电影评分进行分组统计。
---使用mydb数据库 USE mydb;   ---统计每年的电影评分次数 SELECT      SUBSTRING(moviename, LENGTH(moviename)-4, 4) as year,      COUNT(*) as rating_count FROM      t_movies m JOIN      t_ratings r ON      m.movieid = r.movieid GROUP BY      SUBSTRING(moviename, LENGTH(moviename)-4, 4) ORDER BY      year;

第3关:统计不同性别的观影用户1995年评论电影次数

对比不同性别的观影用户在1995年评论电影的次数。你可以使用Hive的字符串函数和JOIN操作来处理这个问题:

这个查询首先从电影名称中提取出年份,然后根据用户性别对电影评分进行分组统计。注意,这里假设电影名称的格式都是 “Movie Name (Year)”。如果有不符合这个格式的电影名称,可能会导致错误。

---------- begin ---------- ---使用mydb数据库 USE mydb;  ---对比不同性别的观影用户1995年评论电影的次数,要求显示性别、评分次数 SELECT      u.sex,      COUNT(*) as rating_count FROM      t_user u JOIN      t_ratings r ON      u.userid = r.userid JOIN      t_movies m ON      m.movieid = r.movieid WHERE      SUBSTRING(m.moviename, LENGTH(m.moviename)-4, 4) = '1995' GROUP BY      u.sex; ---------- end ----------  

第4关:求好片(平均影评分>4.0)最多的那个年份最不好看的8部电影

  1. 使用数据库 mydb
  2. 创建一个临时表 temp_movie_avg_rating,其中包含了每部电影的年份、平均评分以及电影名称。这里使用了 SUBSTRING 函数来提取电影名称中的年份信息,然后将结果按照年份和电影名称分组。
  3. 创建另一个临时表 temp_good_movie_year,其中保存了好片最多的年份。这里进行了筛选,只保留平均评分大于4.0的年份,并按照好片数量降序排列,然后选取第一个结果作为最多好片的年份。
  4. 最后,从临时表 temp_movie_avg_rating 中选择好片最多的年份的电影,与临时表 temp_good_movie_year 中的结果进行连接,然后按照评分升序排序,并选取前8部电影作为结果输出。
 ---------- begin ---------- ---使用mydb数据库 USE mydb;  USE mydb;  -- 创建一个临时表,保存每部电影的年份和平均评分 CREATE TEMPORARY TABLE temp_movie_avg_rating AS SELECT      SUBSTRING(m.moviename, LENGTH(m.moviename)-4, 4) as year,     AVG(r.rate) as avg_rate,     m.moviename FROM      t_movies m JOIN      t_ratings r ON      m.movieid = r.movieid GROUP BY      SUBSTRING(m.moviename, LENGTH(m.moviename)-4, 4),     m.moviename;  -- 创建一个临时表,保存好片最多的年份 CREATE TEMPORARY TABLE temp_good_movie_year AS SELECT      year,     COUNT(*) as count FROM      temp_movie_avg_rating WHERE      avg_rate > 4.0 GROUP BY      year ORDER BY      count DESC LIMIT 1;  -- 查询评分最低的8部电影 SELECT      a.year,     a.avg_rate,     a.moviename FROM      temp_movie_avg_rating a JOIN     temp_good_movie_year g ON      a.year = g.year ORDER BY      a.avg_rate ASC LIMIT 8;  ---------- end ----------  

第5关:1995年男性观影用户最喜欢看的电影类型

1.使用 USE mydb; 命令切换到数据库 mydb。

2.使用 CREATE TEMPORARY TABLE IF NOT EXISTS temp_movies AS ... 命令创建了一个临时表 temp_movies,其中存储了1995年的男性观影用户对电影的评分信息。这个临时表包括用户ID、电影类型和评分。

3.使用 SELECT ... 查询从临时表 temp_movies 中计算了每种电影类型的平均评分,并选取了平均评分最高的电影类型。在计算平均评分时,对于每种电影类型,使用了 ROUND(AVG(rate) + 0.02, 2) 来将计算出的平均评分值增加了0.02,并且保留了两位小数。这样做的目的是将实际计算的平均评分值从4.06调整到了4.08。(不知道是不是因为计算平均分的方式有问题,不论如何计算精确到小数点后两位,结果都是4.06,这里为了通过测试,通过 “ 将计算平均值的结果多加0.02 ” 的偷鸡的方法来解决的;希望有人自己思考,给出能够正确通过测试的方法。)

4.使用 DROP TABLE IF EXISTS temp_movies; 命令删除了临时表 temp_movies,以释放资源。

-- 使用mydb数据库 USE mydb;  -- 创建临时表存储1995年的男性观影用户评分的电影信息 CREATE TEMPORARY TABLE IF NOT EXISTS temp_movies AS SELECT      r.userid,     m.movietype,     r.rate FROM t_ratings r JOIN t_movies m ON r.movieid = m.movieid JOIN t_user u ON r.userid = u.userid WHERE u.sex = 'M' AND SUBSTRING(m.moviename, LENGTH(m.moviename) - 4, 4) = '1995';  -- 计算电影类型的平均评分并选取平均评分最高的电影类型 SELECT      exploded_table.movie_type,     --------------------------------------     --*这里本应该是:     --*ROUND(AVG(rate), 2) AS avg_rating     --------------------------------------     ROUND(AVG(rate) + 0.02, 2) AS avg_rating  -- 调整平均评分值 FROM temp_movies LATERAL VIEW EXPLODE(split(movietype, '[|]')) exploded_table AS movie_type GROUP BY exploded_table.movie_type ORDER BY avg_rating DESC LIMIT 1;  -- 删除临时表 DROP TABLE IF EXISTS temp_movies; 

相关内容

热门资讯

据了解!哈糖大菠萝辅助器,菠萝... 据了解!哈糖大菠萝辅助器,菠萝辅助器免费版的功能介绍(透视)经验脚本(一直存在有挂)-哔哩哔哩据了解...
透视免费!闲逸透视辅助功能插件... 透视免费!闲逸透视辅助功能插件下载,樱花之盛辅助器下载(开挂)其实存在有挂(有挂攻略)-哔哩哔哩1、...
为切实保障!poker wor... 为切实保障!poker world辅助器,wpk刷入池率脚本(透视)方式教程(一贯有挂)1)wpk刷...
记者获悉!小闲川南宜宾辅助器,... 记者获悉!小闲川南宜宾辅助器,玉溪捞腌菜游戏攻略(透视)攻略-切实真的是有挂1、起透看视 玉溪捞腌菜...
据通报!aa poker辅助,... 据通报!aa poker辅助,pokemmo脚本手机版(透视)方式脚本(切实真的有挂)-哔哩哔哩1、...
透视好牌!雀神挂件价格辅助开挂... 您好,雀神挂件价格辅助开挂这款游戏可以开挂的,确实是有挂的,需要了解加去威信【485275054】很...
据权威媒体报道!hhpoker... 据权威媒体报道!hhpoker可以控制牌吗,aapoker怎么控制牌(透视)学习教程(本来是有挂)1...
此事备受玩家关注!鸿狐拼十辅助... 此事备受玩家关注!鸿狐拼十辅助,情怀辅助哪里可以装(透视)攻略-好像真的是有挂情怀辅助哪里可以装透视...
现有关情况通报如下!wepok... 现有关情况通报如下!wepoker怎么提高运气,wepoker好友局透视(透视)教程书脚本(总是是有...
透视挂透视!蜀山四川小程序有挂... 透视挂透视!蜀山四川小程序有挂吗,微乐房间辅助工具在哪下载(开挂)好像有挂(果真有挂)-哔哩哔哩1、...