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. 如何用Pivot实现行列转换

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

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

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

  4. sql行列转换

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

  5. Oracle行列转换

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

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

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

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

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

  8. SQL行列转换:报表_公司采购表_每个公司各采购了些什么产品

    有同学问了个比较典型行列转换的问题,想想,解答如下:数据库有一张表: 是个公司采购表,想转化成如下报表,显示每个公司各采购了些什么产品: 哪些公司采购哪些产品是不确定的,所以报表的列有哪几项是不确定的 ...

  9. Sql2008的行列转换之行转列

    今天在工作的时候遇到了行列转换的问题,记得去年有一段时间经常写,但是许久不用已经记不太得了.好记性不如烂笔头,忙完之后赶紧记录一下. 关键字:PIVOT(行转列),UNPIVOT(列转行) 先说说 P ...

随机推荐

  1. angularjs的$on、$emit、$broadcast

    如何在作用域之间通信呢? 1.创建一个单例服务,然后通过这个服务处理所有子作用域的通信. 2.通过作用域中的事件处理通信.但是这种方法有一些限制:例如,你并不能广泛的将事件传播到所有监控的作用域中.你 ...

  2. 轻松自动化---selenium-webdriver(python) (一)

    为什么选python? 之前的菜鸟系列是基于java的,一年没学其实也忘的差不多了,目前所测的产品部分也是python写的,而且团队也在推广python ,其实就测试人员来说,python也相当受欢迎 ...

  3. 组合数取模Lucas定理及快速幂取模

    组合数取模就是求的值,根据,和的取值范围不同,采取的方法也不一样. 下面,我们来看常见的两种取值情况(m.n在64位整数型范围内) (1)  , 此时较简单,在O(n2)可承受的情况下组合数的计算可以 ...

  4. VB 编程

    error播放出错提示音 errorPromptVoice() 返回一个字符串,其中包含从某个字符串右端开始的指定数量的字符 Microsoft.VisualBasic.Right(strBt45Te ...

  5. [MongoDB]Mongodb攻略

    -------------------------------------------------------------------------------------------- [基础] 1. ...

  6. CString + UINT Error:有多个运算符&quot;+=&quot;与这些操作数匹配

    在OnChar中,参数UINT nChar 有一个CString str,现在执行 str += nChar报错:Error:有多个运算符"+="与这些操作数匹配 解决办法:把UI ...

  7. C#_加密解密

    一.MD5加密解密 1.加密 public static string ToMd5(string clearString) { Byte[] clearBytes = System.Text.Enco ...

  8. 机器学习之神经网络模型-上(Neural Networks: Representation)

    在这篇文章中,我们一起来讨论一种叫作"神经网络"(Neural Network)的机器学习算法,这也是我硕士阶段的研究方向.我们将首先讨论神经网络的表层结构,在之后再具体讨论神经网 ...

  9. Linux/Unix shell 自动发送AWR report(二)

    观察Oracle数据库性能,Oracle自带的awr 功能为我们提供了一个近乎完美的解决方案,通过awr特性我们可以随时从数据库提取awr报告.不过awrrpt.sql脚本执行时需要我们提供一些交互信 ...

  10. ubuntu tab命令补全失效

    主要是由于环境变量设置出了问题,修改/etc/environment即可. sudo nano /etc/environment 修改后source /etc/environment