最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

SQLServer行与列之间转换

来源:动视网 责编:小采 时间:2020-11-09 15:51:06
文档

SQLServer行与列之间转换

SQLServer行与列之间转换:SQL Server把行转列: 如以下表: 当表中只有少量数据时,可以采用静态SQL语句 如: select stuName , max(case Course when '语文' then score else 0 end) as 语文, max(case Course when '数学' then score else
推荐度:
导读SQLServer行与列之间转换:SQL Server把行转列: 如以下表: 当表中只有少量数据时,可以采用静态SQL语句 如: select stuName , max(case Course when '语文' then score else 0 end) as 语文, max(case Course when '数学' then score else


SQL Server把行转列: 如以下表: 当表中只有少量数据时,可以采用静态SQL语句 如: select stuName , max(case Course when '语文' then score else 0 end) as 语文, max(case Course when '数学' then score else 0 end) as 数学, max(case Course when '

SQL Server把行转列:

如以下表:

当表中只有少量数据时,可以采用静态SQL语句

如:

select stuName ,
max(case Course when '语文' then score else 0 end) as 语文,
max(case Course when '数学' then score else 0 end) as 数学,
max(case Course when '英语' then score else 0 end) as 英语,
max(case Course when '物理' then score else 0 end) as 物理,
sum(score) as '总分'
from Student group by stuName

当数据表中有大量数据,就必须采用动态SQL语句了

如下操作:

declare @name varchar(8000) --声明变量
set @name = 'select stuName '
select @name = @name + ' , sum(case Course when ''' + Course + ''' then score else 0 end) [' + Course + ']'
from (select distinct Course from Student) as a
set @name = @name + ' from Student group by stuName'
exec(@name)

其中distinct这个关键字用来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的所有值

以上两个结果是一样的,结果如下:

文档

SQLServer行与列之间转换

SQLServer行与列之间转换:SQL Server把行转列: 如以下表: 当表中只有少量数据时,可以采用静态SQL语句 如: select stuName , max(case Course when '语文' then score else 0 end) as 语文, max(case Course when '数学' then score else
推荐度:
标签: 转换 sql 之间
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top