CREATE TABLE score

(

name NVARCHAR(20),

subject NVARCHAR(20),

score INT

)

--2.插入测试数据

INSERT INTO score(name,subject,score) VALUES('张三','语文',98)

INSERT INTO score(name,subject,score) VALUES('张三','数学',80)

INSERT INTO score(name,subject,score) VALUES('张三','英语',90)

INSERT INTO score(name,subject,score) VALUES('李四','语文',88)

INSERT INTO score(name,subject,score) VALUES('李四','数学',86)

INSERT INTO score(name,subject,score) VALUES('李四','英语',88)

INSERT INTO score(name,subject,score) VALUES('李明','语文',60)

INSERT INTO score(name,subject,score) VALUES('李明','数学',86)

INSERT INTO score(name,subject,score) VALUES('李明','英语',88)

INSERT INTO score(name,subject,score) VALUES('林风','语文',74)

INSERT INTO score(name,subject,score) VALUES('林风','数学',99)

INSERT INTO score(name,subject,score) VALUES('林风','英语',59)

INSERT INTO score(name,subject,score) VALUES('严明','英语',96)

select * from score

select subject from score   for xml path('')

SELECT Subject+','  FROM score

    where name='林风'

  FOR XML PATH('')

 

   SELECT  cast(score as varchar)+',' FROM score

    where name='林风'

  FOR XML PATH('')

 

SELECT name ,sum(score),

(SELECT Subject+',' FROM score

  WHERE name=A.name

  FOR XML PATH('')) AS StuList,

 

 

  (SELECT cast(score as varchar(10))+',' FROM score

  WHERE name=A.name

  FOR XML PATH('')) AS StuList

 

 

FROM score A

GROUP BY name

--3.取每个学科的前3名数据

SELECT * FROM

(

SELECT subject,name,score,ROW_NUMBER() OVER(PARTITION BY subject ORDER BY score DESC) AS num FROM score

) T WHERE T.num <= 3 ORDER BY subject

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

SELECT * FROM

(

SELECT subject,name,score,Rank() OVER(PARTITION BY subject ORDER BY score DESC) AS num FROM score

) T WHERE T.num <= 3 ORDER BY subject

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

SELECT * FROM

(

SELECT subject,name,score,Dense_Rank() OVER(PARTITION BY subject ORDER BY score DESC) AS num FROM score

) T WHERE T.num <= 3 ORDER BY subject

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

/*以下是我对4个排名函数的类比表格:         

               排名连续性   排名并列性         

RANK()        不一定连续    有并列         

DENSE_RANK()   连续         有并列         

ROW_NUMBER()   连续         无并列         

NTILE()        连续         有并列         

*/

--4行转列

SELECT name,ISNULL([数学],0) [数学],ISNULL([英语],0) [英语],ISNULL([语文],0) [语文]

FROM score PIVOT (max(score) FOR subject IN ([数学],[英语],[语文]) ) AS pt

SELECT name,ISNULL([数学],0) [数学],ISNULL([英语],0) [英语]

FROM score PIVOT (max(score) FOR subject IN ([数学],[英语]) ) AS pt

SELECT Name AS 姓名 ,

     MAX(CASE Subject WHEN '数学' THEN score ELSE 0 END) [数学] ,

     MAX(CASE Subject WHEN '英语' THEN score ELSE 0 END) [英语] ,

     MAX(CASE Subject WHEN '语文'  THEN score ELSE 0 END) [语文]

   FROM score GROUP BY name

--5动态行转列

declare @sql varchar(8000)

--set @sql = 'select Name as ' + '姓名'

set @sql=''

select @sql = @sql+ ' , max(case Subject when ''' + Subject + ''' then score else 0 end) [' + Subject + ']'

from (select distinct Subject from score) as a

--set @sql = @sql + ' from score group by name'

print @sql

exec(@sql)

--6 动态Pivot

declare @sql varchar(500)

declare @sql2 varchar(500)

select @sql2=  isnull(@sql2 + ',' , '') + 'isnull(['+Subject+'],0) as '+Subject+'' from score group by Subject

select @sql = isnull(@sql + ',' , '') + '['+Subject+']' from score group by Subject

print @sql

print @sql2

exec ('select Name,'+@sql2+' from (

select Name,s.Score,Subject from score s

 

) a pivot (sum(Score) for Subject in (' + @sql + ')) b')

   

SELECT name,sum(score) score,

(SELECT Subject+',' FROM score

  WHERE name=A.name

  FOR XML PATH('')) AS StuList,

  (SELECT cast(score as varchar(10))+',' FROM score

  WHERE name=A.name

  FOR XML PATH('')) AS StuList

FROM score A

GROUP BY name

 


--7 XML PATH

   select b.name,b.score,

   LEFT(b.StuList,LEN(b.StuList)-1) StuList,

   LEFT(b.ScoreList,LEN(b.ScoreList)-1) ScoreList

    from (

    SELECT name,sum(score) score,

(SELECT Subject+',' FROM score

  WHERE name=A.name

  FOR XML PATH('')) AS StuList,

  (SELECT cast(score as varchar(10))+',' FROM score

  WHERE name=A.name

  FOR XML PATH('')) AS ScoreList

FROM score A

GROUP BY name ) b  order by score desc

  

  

Partition分组使用和行列转换的更多相关文章

  1. oracle行列转换函数的使用

    oracle 10g wmsys.wm_concat行列转换函数的使用: 首先让我们来看看这个神奇的函数wm_concat(列名),该函数可以把列值以","号分隔起来,并显示成一行 ...

  2. SQL行列转换6种方法

    在进行报表开发时,很多时候会遇到行列转换操作,很对开发人员针对于SQL级别行列转换操作一直不甚理解,今天正好抽空对其进行了一些简单的总结.这里主要列举3种可以实现SQL行列转换的方法,包括通用SQL解 ...

  3. SQL Fundamentals: 子查询 || 行列转换(PIVOT,UNPIVOT,DECODE),设置数据层次(LEVEL...CONNECT BY)

    SQL Fundamentals || Oracle SQL语言 子查询(基础) 1.认识子查询 2.WHERE子句中使用子查询 3.在HAVING子句中使用子查询 4.在FROM子句中使用子查询 5 ...

  4. 如何用Pivot实现行列转换

    在Oracle中,如果要实现行列转换,较为常见的是用DECODE和CASE语句.对于简单的行列转行,DECODE和CASE语句尚能应付.在逻辑比较复杂,分组聚合较多的场景中,DECODE和CASE语句 ...

  5. 在Sqlserver下巧用行列转换日期的数据统计

    在Sqlserver下巧用行列转换日期的数据统计 前言 在SQLSERVER 中有很多统计函数的基础语法,有使用Group By 或 partition by 后配合Sum,Count(*) 等用法. ...

  6. sql行列转换

    首先我们建立一张表,名为scoreInfo,各个字段的设计如下图,分别是name,course,score,表示姓名,成绩与分数,如图所示.

  7. Oracle行列转换

    一.建表与插入数据 1.1.建表 create table kecheng ( id NUMBER, name ), course ), score NUMBER ); insert into kec ...

  8. 每日学习心得:SQL查询表的行列转换/小计/统计(with rollup,with cube,pivot解析)

    2013-8-20 1.    SQL查询表的行列转换/小计/统计(with  rollup,with cube,pivot解析) 在实际的项目开发中有很多项目都会有报表模块,今天就通过一个小的SQL ...

  9. SQL SERVER 中的行列转换小结

    1. 介绍说明 前段时间组内的小伙伴在升级维护项目中,经常涉及一些复杂的数据转换问题,让我去看下有些地方怎么处理,我发现好多都是涉及到行列转换的问题,处理起来经常会比较麻烦,借此也总结一下,方便以后的 ...

随机推荐

  1. 在代码中调用 mvc 4 api

    mvc 4 api 的调用有很多种,最常见也最简单的一种是 用 ajax 的方式在前端界面中调用, 如果是在后台代码中调用 ,是要复杂一些,以下是 以 post 的方式调用 api 的封装好的方法: ...

  2. 洛谷P2729 饲料调配 Feed Ratios

    P2729 饲料调配 Feed Ratios 36通过 103提交 题目提供者该用户不存在 标签USACO 难度普及/提高- 提交  讨论  题解 最新讨论 暂时没有讨论 题目背景 农夫约翰从来只用调 ...

  3. Android 之 下拉框(Spinner)的使用

    下拉列表 Spinner. Spinner的使用,可以极大提高用户的体验性.当需要用户选择的时候,可以提供一个下拉列表将所有可选的项列出来.供用户选择. Demo如下,可以留作参考 一.使用数组作为数 ...

  4. 第十周java 学习总结

    20145306 java的网络编程 网络概述 网络编程技术是当前一种主流的编程技术,随着联网趋势的逐步增强以及网络应用程序的大量出现,所以在实际的开发中网络编程技术获得了大量的使用.至于以后的实际修 ...

  5. C++ builder 2010 操作Excel表格的编程实现

    //--------------------------------------------------------------------------- #include <vcl.h> ...

  6. ArrayList总结

    ArrayList 1.extends AbstractList 实现List<E>->Collection<e>->Iterable,RandomAccess,S ...

  7. 0511 backlog 项目管理

    SCRUM 这次的作业就是确定SCRUM的计划,确定sprint backlog的一个冲刺周期,而这个周期是两个星期.争取在两周内发布1.0版本. 本次作业以网站构建为主: ID       NAME ...

  8. 响应式Web设计基础

    本文所有内容来自Responsive Web Design Fundamentals 手机.大屏手机.平板电脑.桌面电脑.游戏控制台.电视.甚至是可穿戴设备,如此多的设备也形成了多种多样的屏幕尺寸.屏 ...

  9. 017Makefile工程管理

    1.为什么需要Makefile? 利用Makefile和make的合作,可以把很多很多的工作合并成一个非常简单的命令:make: make能够使整个程序的编译.链接只需要一个命令(make)就可以完成 ...

  10. 将Windows 7导航窗格中的收藏夹、库、家庭组、网络全部去掉

    将Windows 7导航窗格中的收藏夹.库.家庭组.网络全部去掉,只剩下计算机.右键单击ShellFolder,选择权限->Administrators,勾选上“完全控制”,确定后双击右侧窗格中 ...