Hive SQL必刷练习题:排列组合问题【通过join不等式】

排列组合问题【通过join不等式】

这种问题,就是数学的排列不等式,一个队伍只能和其余队伍比一次,不能重复

方法1:可以直接通过join,最后on是一个不等式【排列组合问题的解决方式】

方法2:也可以是提前多加一列,加上一个序号

方法1

sql 复制代码
select
t1.team_name team_name_2,
t2.team_name team_name_1
from
(
    select
        team_name,
        case
        when team_name='湖人' then 2
        when team_name='骑士' then 4
        when team_name='勇士' then 1
        else 3 end flag
    from team
) t1
join
(
    select
        team_name,
        case
        when team_name='湖人' then 2
        when team_name='骑士' then 4
        when team_name='勇士' then 1
        else 3 end flag
    from team
) t2 
on t1.flag > t2.flag

方法2

sql 复制代码
select 
	team_name team_name_1,
	team_name_2
from
team
join( 
    select team_name team_name_2
    from team
)t1
on team_name < team_name_2

另外的思路:

​ 也还有种思路,我就是想这样,不过没成功,就是通过炸裂函数+开窗

-- 思路:

-- 通过理解题意 明白了每个队伍只比一次其实就是一个数学的关联问题

-- 所以就想到了使用开窗函数和高级聚合函数和炸裂函数

-- 先通过高级聚合函数 开窗 将当前行的值到最后一行的队伍名封装到一个集合中

-- 然后将集合再炸裂开 并将两个队伍名字相同的行过滤掉即可得出想要的结果

sql 复制代码
SELECT 
t2.team_name team_name_1,
t2.team_name2 team_name_2 
FROM ( 
  SELECT 
  	t1.team_name, 
  	team_name2 
  FROM 
  ( SELECT 
        team_name, 
        collect_list(team_name) OVER (ORDER BY team_name ROWS BETWEEN CURRENT ROW AND UNBOUNDED FOLLOWING) name_list 
FROM team 
) t1 
  LATERAL VIEW explode(t1.name_list) temp AS team_name2 
) t2 
WHERE t2.team_name != t2.team_name2
相关推荐
大数据CLUB2 小时前
基于spark的澳洲光伏发电站选址预测
大数据·hadoop·分布式·数据分析·spark·数据开发
计算机编程小央姐4 小时前
跟上大数据时代步伐:食物营养数据可视化分析系统技术前沿解析
大数据·hadoop·信息可视化·spark·django·课程设计·食物
懒虫虫~7 小时前
通过内存去重替换SQL中distinct,优化SQL查询效率
java·sql·慢sql治理
逛逛GitHub8 小时前
1 个神级智能问数工具,刚开源就 1500 Star 了。
sql·github
IT学长编程9 小时前
计算机毕业设计 基于Hadoop的健康饮食推荐系统的设计与实现 Java 大数据毕业设计 Hadoop毕业设计选题【附源码+文档报告+安装调试】
java·大数据·hadoop·毕业设计·课程设计·推荐算法·毕业论文
Huhbbjs9 小时前
SQL 核心概念与实践总结
开发语言·数据库·sql
咋吃都不胖lyh9 小时前
SQL-字符串函数、数值函数、日期函数
sql
sensenlin919 小时前
Mybatis中SQL全大写或全小写影响执行性能吗
数据库·sql·mybatis
Lx35212 小时前
Hadoop数据一致性保障:处理分布式系统常见问题
大数据·hadoop
IT学长编程13 小时前
计算机毕业设计 基于Hadoop豆瓣电影数据可视化分析设计与实现 Python 大数据毕业设计 Hadoop毕业设计选题【附源码+文档报告+安装调试
大数据·hadoop·python·django·毕业设计·毕业论文·豆瓣电影数据可视化分析