当前位置: 代码迷 >> Sql Server >> 求个sql,该如何处理
  详细解决方案

求个sql,该如何处理

热度:62   发布时间:2016-04-24 22:53:45.0
求个sql
已知表tab,结构和数据如下
季度JD  班级BJ   成绩CJ
1       a       80
1       b       89
1       c       78
2       a       55  
2       b       51
3       a       89

求个sql,按照如下格式显示结果
        班级a   班级b    班级c      
季度1    80       89        78
季度2    55       51
季度3    89

------解决方案--------------------
declare @sql nvarchar(max)
select @sql=isnull(@sql,'')+',max(case when bj='''+bj+''' then cj else 0 end)[班级'+bj+']' from(select distinct bj from tb)t
exec('select jd=''季度''+rtrim(jd)'+@sql+' from tb group by jd')
  相关解决方案