leetcode 1264页面推荐(postgresql)

需求

朋友关系列表: Friendship

±--------------±--------+

| Column Name | Type |

±--------------±--------+

| user1_id | int |

| user2_id | int |

±--------------±--------+

这张表的主键是 (user1_id, user2_id)。

这张表的每一行代表着 user1_id 和 user2_id 之间存在着朋友关系。

喜欢列表: Likes

±------------±--------+

| Column Name | Type |

±------------±--------+

| user_id | int |

| page_id | int |

±------------±--------+

这张表的主键是 (user_id, page_id)。

这张表的每一行代表着 user_id 喜欢 page_id。

写一段 SQL 向user_id = 1 的用户,推荐其朋友们喜欢的页面。不要推荐该用户已经喜欢的页面。

你返回的结果中不应当包含重复项。

输入

输出

sql 复制代码
with t1 as (select case
                       when user1_id = 1 then user2_id
                       else user1_id
                       end as fri_id
            from friendship
            where user1_id = 1
               or user2_id = 1)
select distinct page_id
from t1,
     likes
where t1.fri_id = Likes.user_id
  and Likes.page_id != (select page_id from likes where user_id = 1)
order by page_id;
相关推荐
凯子坚持 c几秒前
Redis 事务深度解析:从基础到实践
数据库·redis·缓存
JAVA学习通3 分钟前
零基础OSS组件(Java)
java·linux·leetcode
啊吧怪不啊吧37 分钟前
初识SQL
服务器·数据库·sql
FIavor.38 分钟前
程序包org.junit.jupiter.api不存在这怎么办
数据库·junit·sqlserver
小猪咪piggy1 小时前
【项目】年会抽奖系统
数据库·oracle
枫叶_v1 小时前
【DB】Oracle转MySQL
数据库·mysql·oracle
yuniko-n1 小时前
【力扣 SQL 50】连接
数据库·后端·sql·算法·leetcode
自己收藏学习1 小时前
统计订单总数并列出排名
数据库·sql·mysql
TiAmo zhang1 小时前
SQL Server 2019实验 │ 安装及其管理工具的使用
数据库·sqlserver
MZZDX2 小时前
MySQL相关知识总结
数据库·mysql