日期:2014-05-18 浏览次数:20587 次
SQL codeselect 'NOU' as NAME, sum(case when day(TIME)=1 then NOU else 0 end) as [1], sum(case when day(TIME)=2 then NOU else 0 end) as [2], ...... sum(case when day(TIME)=31 then NOU else 0 end) as [31] from STU union all select 'NOY' as NAME, sum(case when day(TIME)=1 then NOY else 0 end) as [1], sum(case when day(TIME)=2 then NOY else 0 end) as [2], ...... sum(case when day(TIME)=31 then NOY else 0 end) as [31] from STU
------解决方案--------------------
用 for xml path()
------解决方案--------------------
你这个是典型的行列转换问题,如果数据库的兼容行在sql server 2005以下(不包含Sql server 2005)的话,可以使用1楼的方法,如果兼容性在sql server 2005和sql server 2005以上的话,可以使用pivot语句实现。具体可以参照:http://msdn.microsoft.com/en-us/library/ms177410.aspx或http://www.cnblogs.com/zhangzt/archive/2010/07/29/1787825.html
------解决方案--------------------
select time,sum(NOU), sum(NOY) from Table group by TIME
再通过SQL2005的行列转行即可