SQL行转列汇总
PIVOT 用于将列值旋转为列名(即行转列),在 SQL Server 2000可以用聚合函数配合CASE语句实现 PIVOT 的一般语法是:PIVOT(聚合函数(列) FOR 列 in (…) )AS P 注意:PIVOT、UNPIVOT是SQL Server 2005 的语法,使用需修改数据库兼容级别(在数据库属性->选项->兼容级别改为 90 ) SQL2008 中可以直接使用 完整语法: table_source PIVOT( 聚合函数(value_column) FOR pivot_column IN(<column_list>) ) UNPIVOT 用于将列明转为列值(即列转行),在SQL Server 2000可以用UNION来实现 完整语法: table_source UNPIVOT( value_column FOR pivot_column IN(<column_list>) ) 典型实例 一、行转列 1、建立表格 IF OBJECT_ID('tb') IS NOT NULL DROP TABLE tb go 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) go SELECT * FROM tb go 姓名 课程 分数 ---------- ---------- ----------- 张三 语文 74 张三 数学 83 张三 物理 93 李四 语文 74 李四 数学 84 李四 物理 94 2、使用SQL Server 2000静态SQL SELECT 姓名, 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 姓名 3、使用SQL Server 2000动态SQL --SQL SERVER 2000动态SQL,指课程不止语文、数学、物理这三门课程。(以下同) --变量按sql语言顺序赋值 declare @sql varchar(500) set@sql='select姓名' select @sql=@sql+',max(case课程when '''+课程+''' then分数else 0 end)['+课程+']' from(select distinct 课程 from tb )a--同from tb group by课程,默认按课程名排序 set @sql=@sql+' from tb group by姓名' exec(@sql) --使用isnull(),变量先确定动态部分 declare @sql varchar(8000) select @sql=isnull(@sql+',','')+' max(case课程when '''+课程+''' then分数else 0 end) ['+课程+']' from(select distinct 课程 from tb)asa set @sql='select姓名,'+@sql+' from tb group by姓名' exec(@sql) 4、使用SQL Server 2005静态SQL SELECT * FROM tb pivot( MAX(分数) FOR 课程 IN (语文,数学,物理))a
姓名 语文 数学 物理 ---------- ----------- ----------- ----------- 李四 74 84 94 张三 74 83 93 5、使用SQL Server 2005动态SQL --使用stuff() DECLARE @sql VARCHAR(8000) SET @sql='' --初始化变量 @sql SELECT @sql= @sql+',' + 课程 FROM tb GROUP BY 课程 --变量多值赋值 SET @sql= STUFF(@sql,1,1,'')--去掉首个',' SET @sql='select * from tb pivot (max(分数) for 课程 in ('+@sql+'))a' PRINT @sql exec(@sql) --或使用isnull() DECLARE @sql VARCHAR(8000) --获得课程集合 SELECT @sql= ISNULL(@sql+',','')+课程 FROM tb
GROUP BY 课程 SET @sql='select * from tb pivot (max(分数) for 课程 in ('+@sql+'))a' exec(@sql) 二、行转列结果加上总分、平均分 1、使用SQL Server 2000静态SQL --SQL SERVER 2000静态SQL select姓名, max(case 课程 when'语文' then 分数 else 0 end)语文, max(case 课程 when'数学' then 分数 else 0 end)数学, max(case 课程 when'物理' then 分数 else 0 end)物理, sum(分数)总分, cast(avg(分数*1.0)as decimal(18,2))平均分 from tb group by 姓名 姓名 语文 数学 物理 总分 平均分 ---------- ----------- ----------- ----------- ----------- 李四 74 84 94 252 84.00 张三 74 83 93 250 83.33 2、使用SQL Server 2000动态SQL --SQL SERVER 2000动态SQL declare@sqlvarchar(500) set @sql='select姓名' select @sql=@sql+',max(case课程when '''+课程+''' then分数else 0 end)['+课程+']' from(select distinct 课程 from tb)a set @sql=@sql+',sum(分数)总分,cast(avg(分数*1.0) as decimal(18,2)) 平均分from tb group by姓名' exec(@sql) 3、使用SQL Server 2005静态SQL SELECT m.* ,
n.总分 ,
n.平均分
FROM ( SELECT *
FROM tb PIVOT( MAX(分数) FOR 课程 IN ( 语文, 数学, 物理 ) ) a
) m ,
( SELECT 姓名 ,
SUM(分数) 总分 ,
CAST(AVG(分数 * 1.0) AS DECIMAL(18, 2)) 平均分
FROM tb
GROUP BY 姓名
) n
WHERE m.姓名 = n.姓名 4、使用SQL Server 2005动态SQL --使用stuff()
DECLARE @sql VARCHAR(8000) SET @sql = ''
--初始化变量@sql SELECT @sql = @sql + ',' + 课程
FROM tb
GROUP BY 课程
--变量多值赋值 --同select @sql = @sql + ','+课程 from (select distinct 课程 from tb)a SET @sql = STUFF(@sql, 1, 1, '')
--去掉首个',' SET @sql = ' select m.* , n.总分,n.平均分 from (select * from (select * from tb) a pivot (max(分数) for 课程 in (' + @sql
+ ')) b) m , (select 姓名,sum(分数)总分, cast(avg(分数*1.0) as decimal(18,2)) 平均分 from tb group by 姓名) n where m.姓名= n.姓名' EXEC(@sql) --或使用isnull() DECLARE @sql VARCHAR(8000) SELECT @sql = ISNULL(@sql + ',', '') + 课程
FROM tb
GROUP BY 课程 SET @sql = 'select m.* , n.总分,n.平均分 from (select * from (select * from tb) a pivot (max(分数) for 课程 in (' + @sql
+ ')) b) m , (select 姓名,sum(分数)总分, cast(avg(分数*1.0) as decimal(18,2)) 平均分 from tb group by 姓名) n where m.姓名= n.姓名' EXEC(@sql) 二、列转行 1、建立表格 IF OBJECT_ID('tb') IS NOT NULL DROP TABLE tb
go CREATE TABLE tb(姓名 VARCHAR(10),语文 INT,数学 INT,物理 INT) INSERT INTO tb VALUES('张三',74,83,93) INSERT INTO tb VALUES('李四',74,84,94) go SELECT * FROM tb 姓名 语文 数学 物理 ---------- ----------- ----------- ----------- 张三 74 83 93 李四 74 84 94 2、使用SQL Server 2000静态SQL --SQL SERVER 2000静态SQL。 select * from ( select 姓名,课程='语文',分数=语文 from tb union all select 姓名,课程='数学',分数=数学 from tb union all select 姓名,课程='物理',分数=物理 from tb ) t order by 姓名,case 课程 when '语文' then 1 when '数学' then 2 when '物理' then 3 end 姓名 课程 分数 ---------- ---- ----------- 李四 语文 74 李四 数学 84 李四 物理 94 张三 语文 74 张三 数学 83 张三 物理 93 2、使用SQL Server 2000动态SQL --SQL SERVER 2000动态SQL。 --调用系统表动态生态。 declare @sql varchar(8000) select @sql=isnull(@sql+' union all ','')+' select姓名, [课程]=' +quotename(Name,'''')+' , [分数] = '+quotename(Name)+' from tb' from syscolumns where Name!='姓名'and ID=object_id('tb')--表名tb,不包含列名为姓名的其他列 order by colid exec(@sql+' order by姓名') go 3、使用SQL Server 2005静态SQL --SQL SERVER 2005动态SQL SELECT 姓名 ,
课程 ,
分数
FROM tb UNPIVOT ( 分数 FOR 课程 IN ( [语文], [数学], [物理] ) ) t 4、使用SQL Server 2005动态SQL --SQL SERVER 2005动态SQL DECLARE @sql NVARCHAR(4000) SELECT @sql = ISNULL(@sql + ',', '') + QUOTENAME(name)
FROM syscolumns
WHERE id = OBJECT_ID('tb')
AND name NOT IN ( '姓名' )
ORDER BY colid SET @sql = 'select 姓名,[课程],[分数] from tb unpivot ([分数] for [课程] in(' + @sql
+ '))b' EXEC(@sql)

出处:http://www.cnblogs.com/maanshancss/

Ms sql行转列。汇总的更多相关文章

  1. SQL行转列汇总

    PIVOT用于将列值旋转为列名(即行转列),在SQL Server 2000可以用聚合函数配合CASE语句实现 PIVOT的一般语法是:PIVOT(聚合函数(列) FOR 列 in (…) )AS P ...

  2. SQL行转列汇总 (转)

    PIVOT 用于将列值旋转为列名(即行转列),在 SQL Server 2000可以用聚合函数配合CASE语句实现 PIVOT 的一般语法是:PIVOT(聚合函数(列) FOR 列 in (…) )A ...

  3. 转 SQL行转列汇总

    1.PIVOT 用于将列值旋转为列名(即行转列) PIVOT 的一般语法是:PIVOT(聚合函数(列名) FOR 列名 in (列值1,…) )AS P select * from TB pivot ...

  4. PCB MS SQL 行转列(动态拼SQL)

    一.原数据: SELECT inman,indate FROM [fp_db].[dbo].[ppezhpbb] WHERE indate > '2016-5-1' AND indate < ...

  5. PCB MS SQL 行转列

    一.原数据: SELECT inman,indate FROM [fp_db].[dbo].[ppezhpbb] WHERE indate > '2016-5-1' AND indate < ...

  6. postgresql高级应用之行转列&汇总求和

    postgresql高级应用之行转列&汇总求和 轉載請注名出處 https://www.cnblogs.com/funnyzpc/p/14732165.html 前言 节前公司业务方需要做一個 ...

  7. SQL 行转列和列转行

    SQL 行转列和列转行 行列互转,是一个经常遇到的需求.实现的方法,有case when方式和2005之后的内置pivot和unpivot方法来实现. 在读了技术内幕那一节后,虽说这些解决方案早就用过 ...

  8. sql 行专列 列转行 普通行列转换

    转载:http://www.cnblogs.com/newwind521/archive/2010/11/25/1887203.html sql 行专列 列转行 普通行列转换 /* 标题:普通行列转换 ...

  9. sql 行转列 PIVOT 列转行 UNPIVOT

    原文:sql 行转列 PIVOT 列转行 UNPIVOT 一: 现有表一(t_table1),想转为表二(t_table2)的格式. 表一: 年 公司 收入 2013 公司1 12 2013 公司2 ...

随机推荐

  1. PetaPoco ORM 增加返回DataTable的方法

    public DataTable ExecuteDataTable(Sql sql) { return ExecuteDataTable(sql.SQL, sql.Arguments); } publ ...

  2. Centos 6.5编译安装yum

    1.删除redhat原有的yum rpm -aq|grep yum|xargs rpm -e --nodeps 2.下载yum安装文件 wget http://mirrors.163.com/cent ...

  3. Mysql与Oracle区别

    1.Oracle是大型数据库而Mysql是中小型数据库,Oracle市场占有率达40%,Mysql只有20%左右,同时Mysql是开源的而Oracle价格非常高. 2.Oracle支持大并发,大访问量 ...

  4. Beta版本冲刺——day5

    No Bug 031402401鲍亮 031402402曹鑫杰 031402403常松 031402412林淋 031402418汪培侨 031402426许秋鑫 站立式会议 今日计划表 人员 工作 ...

  5. Ajax 提交session实效跳转到完整的登陆页面

    在spring security 中 Ajax提交时,session超时,局部加载登陆页面,为解决这个问题,重写ajax提交,返回的是modeview或者没有制定datatype时; 如果检测到加载到 ...

  6. sqlserver添加表、字段注释

    引用 :http://begoodluck.blog.163.com/blog/static/20450728020141191412788/ 1.sqlserver用语句给表注释EXECUTE sp ...

  7. Android生命周期

    Android的生命周期如下图所示: A和B两个Activity,从A启动B活动.执行的方法: A活动 onCreate() onStart() onResume()                 ...

  8. easyUI+mvc权限管理后台

    通过按钮和菜单,组合成基本的功能,菜单的功能可以编码修改,但浏览功能是菜单基本的入口,只有角色赋予了浏览功能,才能访问. 基本按钮表 菜单模块 菜单分配按钮 角色授权 下面是对一张表的基本操作 模型 ...

  9. 使Eclipse下支持编写HTML/JS/CSS/JSP页面的自动提示。

    我们平时用eclipse开发jsp页面时智能提示效果不太理想,今天用了两个小时发现了eclipse也可以像Visual Studio 2008那样完全智能提示HTML/JS/CSS代码,使用eclip ...

  10. vs 配置宏

    Win_$(PROCESSOR_ARCHITECTURE)_$(PlatformArchitecture) <==> Win_x86_64 OR Win_x86_32$(Configura ...