SQL面试题:产生连续数值

简介: HiveSQL面试题,不借助其他表产生连续数值

题目:使用SQL产生1-1000的连续数值,不借助其他表

结果如下:

12345...
1000

思路:不借助其他表,也就不能采用join方式产生笛卡尔积,其实我们可以想到用lateral view展开,这就就能展开N行,有了这个想法,我们就可以开始写SQL了

解法一:lateral view+posexplode组合,这种方式在前面的文章已经介绍多次

https://developer.aliyun.com/article/787123?spm=a2c6h.13148508.setting.27.36354f0ebKT1cl

--MaxComputer测试环境selectstart+pos as id
from(select1as start,1000as end
) m  
lateral view posexplode(split(repeat(',s',end-start),',')) t as pos, val;id
1234567891011...
1000

解法二:lateral view+explode组合

--MaxComputer测试环境select  row_number() over()as id
from(select split(repeat(',s',999),',')as x
)m 
lateral view explode(x) ex as tt;id
1234567891011...
1000

当然实现的方法有很多,欢迎大家交流

拜了个拜

目录
相关文章
|
1月前
|
SQL 数据库
SQL面试50题------(初始化工作、建立表格)
这篇文章提供了SQL面试中可能会遇到的50道题目的建表和初始化数据的SQL脚本,包括学生、教师、课程和成绩表的创建及数据插入示例。
SQL面试50题------(初始化工作、建立表格)
|
4月前
|
SQL 关系型数据库 MySQL
MYSQL-SQL语句性能优化策略以及面试题
MYSQL-SQL语句性能优化策略以及面试题
97 1
|
1月前
|
SQL
sql面试50题------(1-10)
这篇文章提供了SQL面试中的前10个问题及其解决方案,包括查询特定条件下的学生信息、教师信息和课程成绩等。
sql面试50题------(1-10)
|
1月前
|
SQL
sql面试50题------(11-20)
这篇文章提供了SQL面试中的50道题目,其中详细解释了11至20题,包括查询与学号为“01”的学生所学课程相同的学生信息、不及格课程的学生信息、各科成绩统计以及学生的总成绩排名等问题的SQL查询语句。
|
1月前
|
SQL
sql面试50题------(21-30)
这篇文章是SQL面试题的21至30题,涵盖了查询不同老师所教课程的平均分、按分数段统计各科成绩人数、查询学生平均成绩及其名次等问题的SQL查询语句。
sql面试50题------(21-30)
|
2月前
|
存储 SQL 索引
面试题MySQL问题之使用SQL语句创建一个索引如何解决
面试题MySQL问题之使用SQL语句创建一个索引如何解决
44 1
|
3月前
|
SQL 大数据
常见大数据面试SQL-每年总成绩都有所提升的学生
一张学生成绩表(student_scores),有year-学年,subject-课程,student-学生,score-分数这四个字段,请完成如下问题: 问题1:每年每门学科排名第一的学生 问题2:每年总成绩都有所提升的学生
|
3月前
|
SQL 关系型数据库 MySQL
sql面试题库
sql面试题库
|
2月前
|
SQL Java 关系型数据库
Java面试题:描述JDBC的工作原理,包括连接数据库、执行SQL语句等步骤。
Java面试题:描述JDBC的工作原理,包括连接数据库、执行SQL语句等步骤。
45 0
|
2月前
|
SQL 监控 Java
Java面试题:简述数据库性能优化的常见手段,如索引优化、SQL语句优化等。
Java面试题:简述数据库性能优化的常见手段,如索引优化、SQL语句优化等。
162 0