数据库 
首页 > 数据库 > 浏览文章

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

(编辑:jimmy 日期: 2024/5/15 浏览:3 次 )

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

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 EXISTS 运算符
下一篇:sql server数据库中raiserror函数用法的详细介绍
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网