SQL进阶技巧:如何分析可能好有问题?
创始人
2024-11-14 14:34:49

目录

0 问题描述

1 数据准备

2 数据分析

3 小结


0 问题描述

给定每个用户的好友列表,好友关系是互相对称的,返回每个用户的可能好友。如果两个用户不是好友关系,并且两者拥有至少一个(或者两个)共同好友,则两者互相是可能好友。

1 数据准备

--建表语句 create table maybe_friend(id string, friends string) row format delimited fields terminated by ' '; load data local inpath '/temp/sql.txt' into table maybe_friend;  --数据:用户id、好友id列表 A B,C,D B A,C,E C A,B,D,E,F D A,C,F E B,C F C,D

2 数据分析

--sql语句 --创建临时表,将好友关系分解为最细粒度 with friend as ( select id, friend from common_friend lateral view explode(split(friends, ',')) temp as friend)  --将具有至少两个共同好友的临时表与好友关系表进行连接,如果临时表的两个用户是好友关系,则在好友关系表中存在对应记录,否则不存在对应记录, --表示两者是可能好友 select t2.id1, t2.id2 from 

相关内容

热门资讯

裸辞做“一人公司”,我后悔了 去年这个时候,一位以色列程序员正在东南亚旅行。他顺手把一个在脑子里转了很久的想法做成了产品,一个让任...
南京建成国内首个Pre-6G试... 4月21日,2026全球6G技术与产业生态大会在南京开幕。全息互动技术展台前,一名远在北京的工作人员...
超梵求职受邀参加“2025抖音... 超梵求职受邀参加“2025抖音巨量引擎成人教育行业生态大会”,探讨分享优质内容传播,服务万千学员。 ...
摩托罗拉Razr 2026(R... IT之家 4 月 22 日消息,摩托罗拉宣布新一代 Razr 折叠手机将于 4 月 29 日在美国发...
库克卸任,特纳斯领航:苹果新纪... 苹果首席执行官蒂姆·库克将卸任,硬件工程主管约翰·特纳斯将接任,苹果公司今天宣布此事。 库克将在夏季...