Partition分组使用和行列转换
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分组使用和行列转换的更多相关文章
- oracle行列转换函数的使用
oracle 10g wmsys.wm_concat行列转换函数的使用: 首先让我们来看看这个神奇的函数wm_concat(列名),该函数可以把列值以","号分隔起来,并显示成一行 ...
- SQL行列转换6种方法
在进行报表开发时,很多时候会遇到行列转换操作,很对开发人员针对于SQL级别行列转换操作一直不甚理解,今天正好抽空对其进行了一些简单的总结.这里主要列举3种可以实现SQL行列转换的方法,包括通用SQL解 ...
- SQL Fundamentals: 子查询 || 行列转换(PIVOT,UNPIVOT,DECODE),设置数据层次(LEVEL...CONNECT BY)
SQL Fundamentals || Oracle SQL语言 子查询(基础) 1.认识子查询 2.WHERE子句中使用子查询 3.在HAVING子句中使用子查询 4.在FROM子句中使用子查询 5 ...
- 如何用Pivot实现行列转换
在Oracle中,如果要实现行列转换,较为常见的是用DECODE和CASE语句.对于简单的行列转行,DECODE和CASE语句尚能应付.在逻辑比较复杂,分组聚合较多的场景中,DECODE和CASE语句 ...
- 在Sqlserver下巧用行列转换日期的数据统计
在Sqlserver下巧用行列转换日期的数据统计 前言 在SQLSERVER 中有很多统计函数的基础语法,有使用Group By 或 partition by 后配合Sum,Count(*) 等用法. ...
- sql行列转换
首先我们建立一张表,名为scoreInfo,各个字段的设计如下图,分别是name,course,score,表示姓名,成绩与分数,如图所示.
- Oracle行列转换
一.建表与插入数据 1.1.建表 create table kecheng ( id NUMBER, name ), course ), score NUMBER ); insert into kec ...
- 每日学习心得:SQL查询表的行列转换/小计/统计(with rollup,with cube,pivot解析)
2013-8-20 1. SQL查询表的行列转换/小计/统计(with rollup,with cube,pivot解析) 在实际的项目开发中有很多项目都会有报表模块,今天就通过一个小的SQL ...
- SQL SERVER 中的行列转换小结
1. 介绍说明 前段时间组内的小伙伴在升级维护项目中,经常涉及一些复杂的数据转换问题,让我去看下有些地方怎么处理,我发现好多都是涉及到行列转换的问题,处理起来经常会比较麻烦,借此也总结一下,方便以后的 ...
随机推荐
- python常见环境安装
pyinotify安装git clone https://github.com/seb-m/pyinotify.gitcd pyinotify/python setup.py install 安装py ...
- 静态链表 C语言描述
静态链表1.下标为0的游标存放最后存放数据节点的游标,即是第一个没有存放元素(备用链表)的下标2.最后一个的节点存放第一个由数值得下标3.第一个和最后一个都不存放数据 即是备用链表的第一个的下标 4. ...
- Android创建自定义dialog方法详解-样式去掉阴影效果
在自定义组件时,从已有组件源码中会很大收获.就拿progressDialog来说 间接父类是dialog,想了解dialog继承结构可以去百度,或者 从构造器来说ProgressDial ...
- c# 了解委托
public delegate void aHandler(string text); public class A1 { public void Print(string txt) { Consol ...
- DedeCMS中function='Html2Text(@me)的用法分析
本文实例讲述了DedeCMS中function='Html2Text(@me)的用法.分享给大家供大家参考.具体分析如下: 在使用dedecms建站网站时候,需要用到过滤html代码,调出纯文本的代码 ...
- Linux设备驱动开发环境的搭建(转)
经过两周的摸索,终于对Linux设备驱动开发有了个初步的认识,下面对Linux设备驱动开发环境的搭建做个小结,以方便自己以后查询,同时也能给同道的初学者一点帮助. 刚接触Linux设备驱动时,初学者往 ...
- 用Java实现一个堆排序
堆可以看成是一个完全二叉树,而且非终端节点的值均不大于(不小于)其左右孩子节点的值.堆排序只需要一个记录大小的辅助空间,输出堆顶的值之后需要对堆进行调整建立新堆,找到剩下节点的最大值(最小值),反复执 ...
- CSS3实现轮播图效果2
先前用CSS3做了一个一张图片实现的轮播,但是这样的图片很难找,于是又改进了一下. HTML: <div class="box"> <ul> <li& ...
- Objective-C数据类型、数据类型转换
数据类型 1.Objective-C数据类型可以分为:基本数据类型.对象数据类型和id类型. 2.基本数据类型有:int.float.double和char类型. 3.对象类型就是类或协议所声明的指针 ...
- [leetcode]_Path Sum I && II
都是考查DFS.经典回溯算法,问题在于我对该类型的代码不熟悉,目前以参考别人的代码,然后加上自己的实现为主,通过类似的题目加强理解. 一.给定一棵二叉树,判断是否存在从root到leaf的路径和等于给 ...