SQL行列转换的另一种方法

create table tb(姓名 varchar(10) , 课程 varchar(10) , 分数 int)
insert into tb values(‘张三‘ , ‘语文‘ , 74)
insert into tb values(‘张三‘ , ‘数学‘ , 83)
insert into tb values(‘张三‘ , ‘物理‘ , 93)
insert into tb values(‘李四‘ , ‘语文‘ , 74)
insert into tb values(‘李四‘ , ‘数学‘ , 84)
insert into tb values(‘李四‘ , ‘物理‘ , 94)
insert into tb values(‘王五‘ , ‘物理‘ , 90)
insert into tb values(‘张六‘ , ‘物理‘ , 100)
go
--SQL SERVER 2000 静态SQL,指课程只有语文、数学、物理这三门课程。(以下同)
select 姓名 as 姓名 ,
  max(case 课程 when ‘语文‘ then 分数 else 0 end) 语文,
  max(case 课程 when ‘数学‘ then 分数 else 0 end) 数学,
  max(case 课程 when ‘物理‘ then 分数 else 0 end) 物理
from tb
group by 姓名
--SQL SERVER 2000 动态SQL,指课程不止语文、数学、物理这三门课程。(以下同)
declare @sql varchar(8000)
set @sql = ‘select 课程 ‘
select @sql = @sql + ‘,max(case 姓名 when ‘‘‘ + 姓名 + ‘‘‘ then 分数 else 0 end) [‘ + 姓名 + ‘]‘
from (select distinct 姓名 from tb) as a
print @sql
set @sql = @sql + ‘ from tb group by 课程‘
exec(@sql) 
go
declare @sql varchar(8000)
set @sql = ‘select 姓名 ‘
select @sql = @sql + ‘ , max(case 课程 when ‘‘‘ + 课程 + ‘‘‘ then 分数 else 0 end) [‘ + 课程 + ‘]‘
from (select distinct 课程 from tb) as a
set @sql = @sql + ‘ from tb group by 姓名‘
exec(@sql) 
go
select * from tb
go
 
--因为没有sql 2005的环境,以下未经测试

--SQL SERVER 2005 静态SQL。

select * from (select * from tb) a pivot (max(分数) for 课程 in (语文,数学,物理)) b

 

--SQL SERVER 2005 动态SQL。

declare @sql varchar(8000)

select @sql = isnull(@sql + ‘],[‘ , ‘‘) + 课程 from tb group by 课程

set @sql = ‘[‘ + @sql + ‘]‘

exec (‘select * from (select * from tb) a pivot (max(分数) for 课程 in (‘ + @sql + ‘)) b‘)

时间: 2025-01-02 14:32:58

SQL行列转换的另一种方法的相关文章

SQL行列转换6种方法

在进行报表开发时,很多时候会遇到行列转换操作,很对开发人员针对于SQL级别行列转换操作一直不甚理解,今天正好抽空对其进行了一些简单的总结.这里主要列举3种可以实现SQL行列转换的方法,包括通用SQL解法以及Oracle支持解法. 一.测试数据 测试表依旧采用Oracle经典的scott模式下的dept表和emp表,结构如下: DEPT: create table DEPT ( DEPTNO NUMBER(2) not null, DNAME VARCHAR2(14), LOC VARCHAR2(

SQL Server遍历表的几种方法 转载

SQL Server遍历表的几种方法 阅读目录 使用游标 使用表变量 使用临时表 在数据库开发过程中,我们经常会碰到要遍历数据表的情形,一提到遍历表,我们第一印象可能就想到使用游标,使用游标虽然直观易懂,但是它不符合面向集合操作的原则,而且性能也比面向集合低.当然,从面向集合操作的角度出发,也有两种方法可以进行遍历表的操作,总结起来,遍历表有下面几种方法. 使用游标 使用表变量 使用临时表 我的需求是:针对HR.Employees表,新增一列fullname,并取值firstname+lastn

javascript浮点数转换成整数三种方法

将浮点数转换成整数方法有很多,分享三种常用方法. Summary 暂时我就想到3个方法而已.如果读者想到其他好用方法,也可以交流一下 parseInt位运算符Math.floor Math.ceil Description 一.parseInt 1. 实例 parseInt("13nash");//13 parseInt("")// NaN parseInt("0xA") //10(十六进制) parseInt(" 13")/

heic转换格式的两种方法:你get到了吗

看到标题是不是很激动呢?一直都不知道怎么转换heic格式的朋友今天碰巧了,苦恼到今天以后就柳暗花明了,其实作为果粉,理应是懂得的,今天直接进入主题,一起来看看怎么转换格式吧! 保证网络能够正常使用,将手机中的图片传到电脑上,等待转换. 辅助转换:1.在电脑上安装苹果HEIC图片转换器并且双击运行,点击"添加图片"即可将电脑中打不开的heic图片都添加到转换器中进行转换: 2.然后修改格式.大小以及画质(图片质量),包括转换器右上角的"输出目录"都可以重新进行修改:

SQL中实现SPLIT函数几种方法总结

例1 代码如下 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 create function f_split(@SourceSql varchar(8000),@StrSeprate varchar(10)) returns @temp table(a varchar(100)) --实现split功能 的函数 --date :2003-10-14 as begin declare

【转】SQL行列转换

原文地址:http://blog.csdn.net/kiki113/article/details/4105929 行列转换等经典SQL语句 1.--行列转换 原表:   姓名     科目   成绩           张三     语文    80           张三     数学    90           张三     物理    85           李四     语文    85           李四     物理    82           李四     英语

oracle高级SQL(四)--SQL行列转换专题2

[上一专题]  行列转换1  -- PIVOT与UNPIVOT函数的介绍 实现案例 1001 lufei 1001 shanzhi 1001 namei 1001 qiaoba 实现效果如下: 1001 lufei,shanzhi,namei,qiaoba 典型的行列转换:实现这种方法有很多. 其中oracle11g之后提供了listagg函数;用来实现上面的效果最好不过了:我们来看下listagg语法 listagg函数的语法结构如下: >listagg( [,]) within group

SQL Server遍历表的几种方法

在数据库开发过程中,我们经常会碰到要遍历数据表的情形,一提到遍历表,我们第一印象可能就想到使用游标,使用游标虽然直观易懂,但是它不符合面向集合操作的原则,而且性能也比面向集合低.当然,从面向集合操作的角度出发,也有两种方法可以进行遍历表的操作,总结起来,遍历表有下面几种方法. 使用游标 使用表变量 使用临时表 我的需求是:针对HR.Employees表,新增一列fullname,并取值firstname+lastname. -- 需求是,新增一列fullname,取值firstname+last

浅谈MySQL中优化sql语句查询常用的30种方法

1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放弃使用索引而进行全表扫描. 3.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而进行全表扫描,如: select id from t where num is null 可以在num上设置默认值0,确保表中num列没有null值,然后这样查询: select id from