评论

收藏

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

数据库 数据库 发布于:2021-06-25 12:08 | 阅读数:240 | 评论:0

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

  现在需要将该列数据分成三列。
  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
  效果
DSC0001.jpg

  第二种
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
  效果
DSC0002.jpg

  第三种
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
  效果
DSC0003.jpg

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

关注下面的标签,发现更多相似文章