欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

SQL 将一列拆分成多列的三种方法

程序员文章站 2022-03-14 18:28:50
数据表中有一列数据,如图所示:现在需要将该列数据分成三列。sql 代码如下所示:第一种select max(case when f1%3=1 then f1 else 0 end) a,max(cas...

数据表中有一列数据,如图所示:

SQL 将一列拆分成多列的三种方法

现在需要将该列数据分成三列。

sql 代码如下所示:

第一种

select 
max(case when f1%3=1 then f1 else 0 end) a,
max(case when f1%3=2 then f1 else 0 end) b,
max(case when f1%3=0 then f1 else 0 end) c
from hlr151
group by (f1-1)/3

效果

SQL 将一列拆分成多列的三种方法

第二种

select 
c1=a.f1,c2=b.f1,c3=c.f1
from hlr151 a
left join hlr151 b on b.f1=a.f1+1 
left join hlr151 c on c.f1=a.f1+2
where (a.f1-1)%3=0

效果

SQL 将一列拆分成多列的三种方法

第三种

select 
max(case when (f1-1)/8=0 then f1 else 0 end) a,
max(case when (f1-1)/8=1 then f1 else 0 end) b,
max(case when (f1-1)/8=2 then f1 else 0 end) c
from hlr151
group by (f1-1)%8

效果

SQL 将一列拆分成多列的三种方法

以上就是sql 将一列拆分成多列的三种方法的详细内容,更多关于sql 一列拆分成多列的资料请关注其它相关文章!

相关标签: sql 拆分