SQL Server中行转列问题的解决方法

发布时间:2019-08-28编辑:脚本学堂
本文介绍了sql数据库中行列转换问题的几种解决方法,有关sql server行列转换的实例代码,有需要的朋友参考下。

在sql数据库中,有如下的数据库表与数据:
 

复制代码 代码示例:

CREATE TABLE TEST
(
   SID VARCHAR(5) NOT NULL,COURSE NVARCHAR(10) NOT NULL, RESULT INT  NOT NULL
)

INSERT INTO TEST VALUES('0001','语文',80)
INSERT INTO TEST VALUES('0001','数学',85)
INSERT INTO TEST VALUES('0001','英语',70)
INSERT INTO TEST VALUES('0001','政治',60)

以下是sql数据库行列转换、行转列的几中方法,大家做个参考。
解决方法1:
 

复制代码 代码示例:

declare @sql varchar(8000)
set @sql='select sid'
select @sql=@sql+','+COURSE+
'=isnull
(
sum(
case course
when
'''+COURSE+'''
then
result end
)
,
0)'
from TEST order by SID

set @sql=@sql+' from TEST group by sid order by sid '
print @sql
exec(@sql)

解决方法2,行列转换语句:
 

复制代码 代码示例:
select sid,语文=isnull(sum(case course when '语文' then result end),0),
数学=isnull(sum(case course when '数学' then result end),0),
英语=isnull(sum(case course when '英语' then result end),0)
from TEST
group by sid
order by sid: