Hive SQL必刷练习题:向用户推荐朋友收藏的商品(两种思路)

问题需求:

需要请向所有用户推荐其朋友收藏但是用户自己未收藏的商品,请从好友关系表(friendship_info)和收藏表(favor_info)中查询出应向哪位用户推荐哪些商品。期望结果如下:

1)部分结果展示

user_id(用户id)sku_id(应向该用户推荐的商品id)
1012
1014
1017
1019
1018
10111
1011

2)相关表结构

好友关系表

user1_id(用户1 iduser2_id(用户2 id
1011010
101108
101106

收藏信息表

user_id(用户id)sku_id(用户id)create_date(收藏日期)
10132021-09-23
101122021-09-23
10162021-09-25

思路分析:

​ 首先明确,这个好友关系表,是互为好友,所以也就是说如果想要找到所有用户的每一个人的所有朋友,需要看用户1 id的朋友 + 用户2 id的朋友。这个就需要借助union了,可以(u1,u2) union (u2,u1)

​ 所有人对应的所有朋友这个找到后,还需要找到所有朋友收藏的商品id,这个就直接用上面union后的表第二列和收藏信息表中的id去join一下就行,不过这里需要注意的是,可能同一个用户的几个朋友的收藏商品中会有重复收藏的,这就需要对用户+商品id进行一下去重。而用户自己收藏的商品,就直接用收藏信息表即可。

-- 这是找到了用户朋友收藏的商品id
-- 所以最后两列是用户自己的id,以及他朋友收藏的商品id
select
	distinct
	t1.user_id,
    sku_id
from(
  SELECT
      user1_id user_id,
      user2_id friend_id 
  from friendship_info
  union
  SELECT
      user2_id,
      user1_id 
  from friendship_info
  )t1 
  left join favor_info
  on favor_info.user_id = t1.friend_id

​ 接下来就是关键的,怎么找到朋友收藏,但是自己没有收藏的商品

这里有两个思路:借助数组,借助join中的****null

​ 数组的思路是说,可以将自己收藏的商品,根据用户id去group by一下,然后使用collect_list,放到一个数组里面,之后和用户-朋友收藏商品id表进行join一下,这样就可以判断一下每个id是不是在自己收藏的商品里面。

​ Join的方法是说,现在有两个表,一个是用户-朋友收藏商品id表,另外一个是用户-自己收藏商品id表,然后我们以第一个表,也就是朋友收藏商品id表为主,进行left join,条件是用户id和商品id一起join,这时候,如果第三列,第四列没有东西,是null,就说明是没有交叉的数据。【比如A left join B的时候,如果左边A表中的元素在B表中没有存在,那么就是null。这时候我们可以通过看哪些元素有null,就知道哪些是A表中存在,但是在B表中不存在的元素】

思路一代码:

select
	user_id,
    sku_id
from(
  select
      distinct
      t1.user_id id,
      sku_id
  from(
    SELECT
        user1_id user_id,
        user2_id friend_id 
    from friendship_info
    union
    SELECT
        user2_id,
        user1_id 
    from friendship_info
  )t1 
  left join favor_info
  on t1.friend_id = favor_info.user_id
)t2  
left join	
(
  select
      user_id,
      collect_list(sku_id) arr
  from favor_info
  group by user_id
)t3
on t2.id = t3.user_id
where !array_contains(arr,sku_id)

思路二代码:

select
distinct 
t1.user_id,
    friend_favor.sku_id
from
(
    select
        user1_id user_id,
        user2_id friend_id
    from friendship_info
    union
    select
        user2_id,
        user1_id
    from friendship_info
)t1
left join 
favor_info friend_favor
on t1.friend_id=friend_favor.user_id
left join 
favor_info user_favor
on t1.user_id=user_favor.user_id
and friend_favor.sku_id=user_favor.sku_id
where user_favor.sku_id is null

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/468563.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【算法专题突破】--- 动态规划 --- 第 N 个泰波那契数 三步问题(1)

1.第 N 个泰波那契数 1.题目解析 这个问题的理解其实相当简单,只需看一下示例,基本就能明白其含义了。 2.算法原理 1. 定义状态表 首先,我们要明白这道题的核心是找出一个序列中的数,这个序列遵循特定的规律:每个数…

简析|创业老隋分享的人力RPO项目如何?

在当今社会,创业热潮席卷而来,各类项目层出不穷。近日,创业老隋分享的人力RPO项目引起了广泛关注。那么,这个项目究竟如何呢?是否靠谱?经过深入了解和分析,我认为这个项目是靠谱的。 首先,从项目的背景和…

idea远程试调jar、远程试调war

idea远程试调jar、远程试调war 目的&#xff1a;测试运行时与ide开发时是否一致。 配置jar Maven中添加 <packaging>jar</packaging>将其打包为jar。 设置运行入口main 编译jar 看到jar输出 配置试调 添加jar运行 远程试调 先在源码中打好断点试调 debug运行…

angularjs 指令实现自定义滚动条

场景&#xff1a;横向商品栏&#xff0c;把原有的滚动条改成自定义的样式&#xff0c;并且给两边加上箭头可以调整&#xff0c;可以拖动商品和滚轮实现滚动条效果。 js appService.directive(customScrollbar, function() {return {restrict: A,transclude: true,scope: {ena…

Docker简介及用途,为什么要使用Docker?Docker容器和虚拟机的区别?

Docker简介 前言 前端有必要学习Docker吗&#xff1f;有&#xff01;&#xff01;不仅要学Docker&#xff0c;还要学习Kubernetes (K8s)&#xff0c;Jenkins 那问题来了&#xff0c;Docker,k8s,jenkins到底要先学习那个呢&#xff1f;当然是Docker 总结来说&#xff0c;先学习…

Cookie 信息泄露 Cookie未设置http only属性 原理以及修复方法

漏洞名称&#xff1a;Cookie信息泄露、Cookie安全性漏洞、Cookie未设置httponly属性 漏洞描述&#xff1a; cookie的属性设置不当可能会造成系统用户安全隐患&#xff0c;Cookie信息泄露是Cookiehttp only配置缺陷引起的&#xff0c;在设置Cookie时&#xff0c;可以设置的一个…

大厂设计师视角下的产品设计完整流程解析!

我相信在激烈的市场竞争中&#xff0c;我们看到了很多半途而废的竞争产品&#xff0c;产品设计过程可以为产品提供很好的解决方案。什么是产品设计过程&#xff1f;产品设计过程由以用户为中心的数字产品设计过程组成&#xff0c;遵循多学科方法。其主要目标是创造优秀的产品&a…

边缘计算+WEB端应用融合:AI行为识别智能监控系统搭建指南 -- 整体介绍(一)

专栏目录 边缘计算WEB端应用融合&#xff1a;AI行为识别智能监控系统搭建指南 – 整体介绍&#xff08;一&#xff09; 边缘计算WEB端应用融合&#xff1a;AI行为识别智能监控系统搭建指南 – 边缘设备图像识别及部署&#xff08;二&#xff09; 边缘计算WEB端应用融合&#xf…

语言、支付、社交:独立站本地化攻略全揭秘,助您征服海外市场

随着全球化的推进和互联网技术的飞速发展&#xff0c;独立站营销已成为许多企业开拓国际市场、提升品牌影响力的重要手段。然而&#xff0c;要在不同国家和地区取得成功&#xff0c;必须制定精准的本地化营销策略&#xff0c;以迎合目标市场的文化和习惯。本文Nox聚星将和大家探…

MB10F-ASEMI适配器专用整流桥MB10F

编辑&#xff1a;ll MB10F-ASEMI适配器专用整流桥MB10F 型号&#xff1a;MB10F 品牌&#xff1a;ASEMI 封装&#xff1a;MBF-4 最大重复峰值反向电压&#xff1a;1000V 最大正向平均整流电流(Vdss)&#xff1a;1A 功率(Pd)&#xff1a;中小功率 芯片个数&#xff1a;4 …

[QJS xmake] 非常简单地在Windows下编译QuickJS!

文章目录 前言准备C编译器xmake编译包 工程准备修改版本号第一遍编译第二遍编译效果 前言 quickjs是个很厉害的东西啊&#xff0c;我一直想编译一下的&#xff0c;奈何一直没成功。现在找了点时间成功编译了&#xff0c;写篇文章记录一下。当前版本&#xff1a;2024-1-13 应该…

python自定义日历库,与对应calendar库函数功能基本一致

目录 自定义日历库 常用列表 日期列表 常用函数 闰年判断 月份天数 元旦序号 日历表头 星期序号 序号及天数 月历字串 打印月历 年历字串 打印年历 对比测试 测试结果 完整代码 运行结果 自定义日历库 自定义日历库函数&#xff0c;并使得其与python calend…

idea 开发serlvet班级通讯录管理系统idea开发mysql数据库web结构计算机java编程layUI框架开发

一、源码特点 idea开发 java servlet 班级通讯录管理系统是一套完善的web设计系统mysql数据库 系统采用serlvetdaobean mvc 模式开发&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。 servlet 班…

KKVIEW远程: TODESK退出了还能远程吗

Todesk退出了还能远程吗 当我们谈论Todesk或其他远程桌面软件时&#xff0c;一个经常被提及的问题是&#xff1a;当我退出Todesk后&#xff0c;是否仍然可以远程访问我的计算机&#xff1f;为了回答这个问题&#xff0c;我们首先需要了解Todesk的工作原理和远程访问的基本条件…

Android和IOS Flutter应用开发使用 Provider.of 时,可以使用 listen: false 来避免不必要的重建

文章目录 listen: false解释示例 listen: false 使用 Provider.of 时&#xff0c;可以使用 listen: false 来避免不必要的重建 解释 当您使用 Provider.of 获取状态对象时&#xff0c;默认情况下&#xff0c;该对象每次发生变化时都会触发重建该对象所在的组件。这在大多数情…

Machine Learning ---- Gradient Descent

目录 一、The concept of gradient&#xff1a; ① In a univariate function&#xff1a; ②In multivariate functions&#xff1a; 二、Introduction of gradient descent cases&#xff1a; 三、Gradient descent formula and its simple understanding: 四、Formula o…

RocketMQ源码分析

文章目录 一、简介二、NameServer的启动过程三、Broker的启动过程四、Netty服务注册框架&#xff08;Netty框架使用的一个很好的案例&#xff09;五、Broker心跳注册过程六、Producer发送消息流程七、Consumer拉取消息的流程八、文件存储九、长轮询消息 RocketMQ源码分析基于版…

苍穹外卖-day15:套餐管理

套餐管理 课程内容 套餐分页查询启售停售套餐删除套餐新增套餐 1. 套餐分页查询 1.1 需求分析和接口设计 根据产品原型来了解需求&#xff0c;套餐分页查询的产品原型如下&#xff1a; 业务规则&#xff1a; 根据页码展示套餐信息(套餐名称、套餐图片、套餐分类、价格、售…

大数据管理平台建设方案书

1.1.系统概述 1.1.1需求描述 1.1.2.需求分析 1.1.3.重难点分析 1.1.4.重难点解决措施 1.2.系统架构设计 1.2.1.系统架构图 1.2.2.关键技术 软件开发全资料获取进主页。

【贪心算法】Leetcode 55. 跳跃游戏 45. 跳跃游戏 I

【贪心算法】Leetcode 55. 跳跃游戏 45. 跳跃游戏 II Leetcode 55. 跳跃游戏解法1 贪心 Leetcode 45. 跳跃游戏I解法 贪心 Leetcode 55. 跳跃游戏 ---------------&#x1f388;&#x1f388;55. 跳跃游戏 题目链接&#x1f388;&#x1f388;------------------- 解法1 贪心…