每日一题:SQL之行转列和列转行

Posted Python学习与数据挖掘

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了每日一题:SQL之行转列和列转行相关的知识,希望对你有一定的参考价值。

每日一题 精选常考面试题,将其汇总成专栏,利用零碎时间为职业保驾护航,建议大家独立思考答题。

资料推荐

题目

数据集

+---+----------+
|id |login_date|
+---+----------+
|01 |2021-02-28|
|01 |2021-03-01|
|01 |2021-03-02|
|01 |2021-03-04|
|01 |2021-03-05|
|01 |2021-03-06|
|01 |2021-03-08|
|02 |2021-03-01|
|02 |2021-03-02|
|02 |2021-03-03|
|02 |2021-03-06|
|03 |2021-03-06|
+---+----------+

以"连续登录"中的数据为例:

select id, 
       concat_ws(',',collect_list(login_date)) cw
from data
group by id;

结果

+---+----------------------------------------------------------------------------+
|id |cw                                                                          |
+---+----------------------------------------------------------------------------+
|01 |2018-02-28,2018-03-01,2018-03-02,2018-03-04,2018-03-05,2018-03-06,2018-03-08|
|02 |2018-03-01,2018-03-02,2018-03-03,2018-03-06                                 |
|03 |2018-03-06                                                                  |
+---+----------------------------------------------------------------------------+

以上面SQL生成的数据为基准,执行下列SQL:

select id, login_date
from t 
lateral  view explode(split(cw,','))  b AS login_date;

结果

+---+----------+
|id |login_date|
+---+----------+
|01 |2018-02-28|
|01 |2018-03-01|
|01 |2018-03-02|
|01 |2018-03-04|
|01 |2018-03-05|
|01 |2018-03-06|
|01 |2018-03-08|
|02 |2018-03-01|
|02 |2018-03-02|
|02 |2018-03-03|
|02 |2018-03-06|
|03 |2018-03-06|
+---+----------+

为更好的交流学习,应读者的要求,我建立了一个交流群,有需要的同学可以在下方公众号后台回复关键字:面试,即可获取快速通道。


后台已放置一份精心整理的技术干货,查看即可获取!后台回复关键字:面试,带你进入高手如云的学习交流群!

以上是关于每日一题:SQL之行转列和列转行的主要内容,如果未能解决你的问题,请参考以下文章

SQL 行转列和列转行

sql面试:sql中的行转列和列转行

Hive 行转列 & 列转行

MySQL行转列与列转行

SAS行转列&&列转行

kettle之行转列,删除多余连接符