微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sqlserver行转列

 

if(object_id('qa') > 0)
   drop table qa
go
create table qa(
   qtcode varchar(100),
   simpleTime varchar(20),
   water decimal(18,2)
)
insert into qa
select 'a','09:10',11 union all
select 'a','10:01',22 union all
select 'a','10:20',33 union all
select 'a','10:30',44 union all
select 'a','10:40',55 union all
select 'b','08:10',12 union all
select 'b',13 union all
select 'b','10:02',14 union all
select 'b',15

select * from qa

declare @sql varchar(3000)
set @sql = 'select qtcode ';
select @sql = @sql + ',(case simpleTime when '''+simpleTime+''' then water else 0 end) ['+simpleTime+']'
 from (select distinct simpleTime from qa) as a
set @sql = @sql+' from qa '
exec(@sql)

declare @sql1 varchar(3000) set @sql1 = 'select qtcode '; select @sql1 = @sql1 + ',max(case simpleTime when '''+simpleTime+''' then water else 0 end) ['+simpleTime+']'  from (select distinct simpleTime from qa ) as a set @sql1 = @sql1+' from qa group by qtcode ' exec(@sql1)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐