一、Pivot和UnPivot介绍
1.Pivot介绍
PIVOT用于将列值旋转为列名(即行转列),在SQL Server 2000可以用聚合函数配合CASE语句实现

PIVOT的一般语法是:PIVOT(聚合函数(列) FOR 列 in (…) )AS P

完整语法:

table_source

PIVOT(

聚合函数(value_column)

FOR pivot_column

IN(<column_list>)

)
2.UnPivot介绍
UNPIVOT用于将列明转为列值(即列转行),在SQL Server 2000可以用UNION来实现

完整语法:

table_source

UNPIVOT(

value_column

FOR pivot_column

IN(<column_list>)

)

注意:PIVOT、UNPIVOT是SQL Server 2005 的语法,使用需修改数据库兼容级别  在数据库属性->选项->兼容级别改为   90

二、行转列实现

1、建立表格

if object_id('TestTB') is not null
drop table TestTB
go create table TestTB(姓名 varchar(10),课程 varchar(10),分数 int) insert into TestTB values('张三','语文',74)
insert into TestTB values('张三','数学',83)
insert into TestTB values('张三','物理',93)
insert into TestTB values('李四','语文',74)
insert into TestTB values('李四','数学',84)
insert into TestTB values('李四','物理',94)
go select * from TestTB

姓名       课程       分数

---------- ---------- -----------

张三       语文        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 TestTB
group by 姓名

姓名       语文        数学        物理

---------- ----------- ----------- -----------

李四        74          84          94

张三        74          83          93

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 TestTB)a--同from TestTB group by课程,默认按课程名排序
set @sql=@sql+' from TestTB group by 姓名'
exec(@sql) --使用isnull(),变量先确定动态部分
declare @sql varchar(8000)
select @sql=isnull(@sql+',','')+' max(case 课程 when '''+课程+''' then 分数 else 0 end) ['+课程+']'
from(select distinct 课程 from TestTB) as a
set @sql='select 姓名,'+@sql+' from TestTB group by 姓名'
exec(@sql)

姓名       数学        物理        语文

---------- ----------- ----------- -----------

李四        84          94          74

张三        83          93          74

4、使用SQL Server 2005静态SQL

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

5、使用SQL Server 2005动态SQL

--使用stuff()
declare @sql varchar(8000)
set @sql='' --初始化变量@sql
select @sql=@sql+','+课程 from TestTB group by 课程--变量多值赋值
set @sql=stuff(@sql,1,1,'')--去掉首个','
set @sql='select * from TestTB pivot (max(分数) for 课程 in ('+@sql+')) a'
exec(@sql) --或使用isnull()
declare @sql varchar(8000)
--获得课程集合
select @sql=isnull(@sql+',','')+课程 from TestTB group by 课程
set @sql='select * from TestTB pivot (max(分数) for 课程 in ('+@sql+')) a'
exec(@sql)

三、行转列结果加上总分、平均分

1、使用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 TestTB
group by 姓名

姓名       语文        数学        物理        总分        平均分

---------- ----------- ----------- ----------- -----------

李四        74          84          94          252         84.00

张三        74          83          93          250         83.33

2、使用SQL Server 2000 动态SQL

declare @sql varchar(500)
set @sql='select 姓名'
select @sql=@sql+',max(case 课程 when '''+课程+''' then 分数 else 0 end)['+课程+']'
from(select distinct 课程 from TestTB)a
set @sql=@sql+',sum(分数)总分,cast(avg(分数*1.0) as decimal(18,2)) 平均分 from TestTB group by 姓名'
exec(@sql)

3、使用SQL Server 2005静态SQL

select m.*,n.总分,n.平均分
from
(select *from TestTB pivot(max(分数) for 课程 in(语文,数学,物理))a)m,
(select 姓名,sum(分数) 总分,cast(avg(分数*1.0) as decimal(18,2)) 平均分
from TestTB
group by 姓名)n
where m.姓名=n.姓名

4、使用SQL Server 2005动态SQL

--使用stuff()
declare @sql varchar(8000)
set @sql='' --初始化变量@sql
select @sql=@sql+','+课程 from TestTB group by 课程--变量多值赋值
--同select @sql = @sql + ','+课程 from (select distinct 课程 from TestTB)a
set @sql=stuff(@sql,1,1,'')--去掉首个','
set @sql='select m.* , n.总分,n.平均分 from
(select * from (select * from TestTB) a pivot (max(分数) for 课程 in ('+@sql+')) b) m ,
(select 姓名,sum(分数) 总分, cast(avg(分数*1.0) as decimal(18,2)) 平均分 from TestTB group by 姓名) n
where m.姓名= n.姓名'
exec(@sql) --或使用isnull()
declare @sql varchar(8000)
select @sql=isnull(@sql+',','')+课程 from TestTB group by 课程
set @sql='select m.* , n.总分,n.平均分 from
(select * from (select * from TestTB) a pivot (max(分数) for 课程 in ('+@sql+')) b) m ,
(select 姓名,sum(分数)总分, cast(avg(分数*1.0) as decimal(18,2)) 平均分 from TestTB group by 姓名) n
where m.姓名= n.姓名'
exec(@sql)

四、列转行实现

1、建立表格

if object_id('TestTB') is not null
drop table TestTB
go
create table TestTB( 姓名 varchar(10),语文 int,数学 int,物理 int)
insert into TestTB values('张三',74,83,93)
insert into TestTB values('李四',74,84,94)
go
select * from TestTB
go

姓名       语文        数学        物理

---------- ----------- ----------- -----------

张三       74          83          93

李四        74          84          94

2、使用SQL Server 2000静态SQL

select * from
(
select 姓名,课程='语文',分数=语文 from TestTB
union all
select 姓名,课程='数学',分数=数学 from TestTB
union all
select 姓名,课程='物理',分数=物理 from TestTB
) as temp
order by 姓名,case 课程 when '语文' then 1 when '数学' then 2 when '物理' then 3 end

姓名       课程 分数

---------- ---- -----------

李四       语文 74

李四       数学 84

李四       物理 94

张三       语文 74

张三       数学 83

张三       物理 93

3、使用SQL Server 2000动态SQL

declare @sql varchar(8000)
select @sql=isnull(@sql+' union all ','')+' select 姓名, [课程]='
+quotename(Name,'''')+' , [分数] = '+quotename(Name)+' from TestTB' from syscolumns
where Name!='姓名' and ID=object_id('TestTB')--表名TestTB,不包含列名为姓名的其他列
order by colid
exec(@sql+' order by 姓名')
go

4、使用SQL Server 2005静态SQL

select 姓名,课程,分数 from TestTB unpivot (分数 for 课程 in([语文],[数学],[物理])) temp

5、使用SQL Server 2005动态SQL

declare @sql nvarchar(4000)
select @sql=isnull(@sql+',','')+quotename(Name) from syscolumns
where ID=object_id('TestTB') and Name not in('姓名') order by Colid
set @sql='select 姓名,[课程],[分数] from TestTB unpivot ([分数] for [课程] in('+@sql+'))b'
exec(@sql)

博客转自:luluping的《SQLServer行列转换 Pivot UnPivot

[转载]SQL Server行列转换实现的更多相关文章

  1. SQL Server 行列转换

    /* 标题:普通行列转换(version 2.0) 作者:范中磊 说明:普通行列转换(version 1.0)仅针对sql server 2000提供静态和动态写法,version 2.0增加sql ...

  2. 12、SQL Server 行列转换

    SQL Server 行转列 在SQL Server 2005中PIVOT 用于将列值转换为列名(行转列),在SQL Server 2000中是没有这个关键字的 只能用case语句实现. --创建测试 ...

  3. SQL SERVER 行列转换(动态)

    行转列测试数据: --测试数据 if not object_id(N'Tempdb..#T') is null drop table #T Go Create table #T([Name] nvar ...

  4. 转载——SQL Server数据库性能优化之SQL语句篇

    转载自:http://www.blogjava.net/allen-zhe/archive/2010/07/23/326927.html 1. 按需索取字段,跟“SELECT *”说拜拜 字段的提取一 ...

  5. Sql的行列转换

    创建表scores 一.传统的行列转换 纵表转横表 我们要转成的横表是这样子的: pivot是sql server 2005 提供的运算符,所以只要数据库在05版本以上的都可以使用.主要用于行和列的转 ...

  6. Sql实现行列转换

    从MS Sql Server 2005微软就推出了pivot和unpivot实现行列转换,这极大的方便了我们存储数据和呈现数据.今天就对这两个关键字进行分析,结合实例讲解如何存储数据,如何呈现数据. ...

  7. SQL Server数据库转换成oracle

    来源:http://blog.csdn.net/hzfu007/article/details/6182151 经常碰到需要把sql server的数据迁移到Oracle的情况. 在网上查找一下,有很 ...

  8. 转载 SQL Server中索引管理之六大铁律

    转载原地址 http://jingyan.baidu.com/article/48a42057c03bd7a924250429.html 索引是以表列为基础的数据库对象.索引中保存着表中排序的索引列, ...

  9. [转载]sql server 等待类型

    下表列出各任务所遇到的等待类型. 等待类型 说明 ASYNC_DISKPOOL_LOCK 当尝试同步并行的线程(执行创建或初始化文件等任务)时出现. ASYNC_IO_COMPLETION 当某任务正 ...

随机推荐

  1. 第八章 Mixer 适配器的应用

    概述: Mixer “知晓”每一次服务间的调用过程,这些调用过程会为Mixer提供丰富的相关信息,Mixer通过接入的适配器对这些信息进行处理,能够在调用的预检(执行前)和报告(执行后)阶段执行多种任 ...

  2. canvas设置线条样式

    canvas设置线条样式 合法属性和方法 lineWidth = value 设置线宽 lineCap = type 设置线端点样式 lineJoin = type 设置线交合处样式 setLineD ...

  3. python 爬虫气象气象定时报 气象预警推送

    "2018-04-09 14时""长沙市""10日(明天)""多云转雷阵雨""29℃""1 ...

  4. C#实现图片文件到数据流再到图片文件的转换

    //----引入必要的命名空间using System.IO;using System.Drawing.Imaging; //----代码部分----// private byte[] photo;/ ...

  5. leetcode303

    public class NumArray { List<int> list = new List<int>(); public NumArray(int[] nums) { ...

  6. 2.spring整合ehcache 注解实现查询缓存,并实现实时缓存更新或删除

    转自:http://www.importnew.com/23358.html 写在前面:上一篇博客写了spring cache和ehcache的基本介绍,个人建议先把这些最基本的知识了解了才能对今天主 ...

  7. Could not load TestContextBootstrapper [null]

    在对SpringBoot进行单元测试时,报错“Could not load TestContextBootstrapper [null]” 错误原因: Maven的pom.xml中某些SpringBo ...

  8. 基础知识 一个工具给win7 win10的同学 或者MAC 可以跳过

  9. DOM 删除HTML元素

    常用方法: <script> var parent=document.getElementById("div1"); var child=document.getEle ...

  10. Laravel 5 项目部署到生产环境的实践

    作者:mrcn链接:https://www.zhihu.com/question/35537084/answer/181734431来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请 ...