SQL Server将一列拆分成多列
时间:2011-02-16 来源:苍马之子
   
图1数据表
现在需要将该列数据分成三列。
SQL 代码如下所示:
1、
  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
效果:
   
2、
  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
效果:
   
3、
  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
效果:
 
 
 相关阅读 更多 + 
    
  









