前言

未来的一个月时间中,会总结一系列SQL知识点,一次只总结一个知识点,尽量说明白,下面来说说SQL 中常用Pivot 函数(这里是用的数据库是SQLSERVER,与其他数据库是类似的,大家放心看就好)

让我们先从一个虚构的场景中来着手吧

万国来朝,很多供应商每天都汇报各自的收入情况。先来创建一个DailyIncome 表

create table DailyIncome(VendorId nvarchar(10), IncomeDay nvarchar(10), IncomeAmount int)

--VendorId 供应商ID,

--IncomeDay 收入时间

--IncomeAmount 收入金额

紧接着来插入数据看看

(留意看下,有的供应商某天中会有多次收入,应该是分批进账的)

insert into DailyIncome values ('SPIKE', 'FRI', 100)

insert into DailyIncome values ('SPIKE', 'MON', 300)

insert into DailyIncome values ('FREDS', 'SUN', 400)

insert into DailyIncome values ('SPIKE', 'WED', 500)

insert into DailyIncome values ('SPIKE', 'TUE', 200)

insert into DailyIncome values ('JOHNS', 'WED', 900)

insert into DailyIncome values ('SPIKE', 'FRI', 100)

insert into DailyIncome values ('JOHNS', 'MON', 300)

insert into DailyIncome values ('SPIKE', 'SUN', 400)

insert into DailyIncome values ('JOHNS', 'FRI', 300)

insert into DailyIncome values ('FREDS', 'TUE', 500)

insert into DailyIncome values ('FREDS', 'TUE', 200)

insert into DailyIncome values ('SPIKE', 'MON', 900)

insert into DailyIncome values ('FREDS', 'FRI', 900)

insert into DailyIncome values ('FREDS', 'MON', 500)

insert into DailyIncome values ('JOHNS', 'SUN', 600)

insert into DailyIncome values ('SPIKE', 'FRI', 300)

insert into DailyIncome values ('SPIKE', 'WED', 500)

insert into DailyIncome values ('SPIKE', 'FRI', 300)

insert into DailyIncome values ('JOHNS', 'THU', 800)

insert into DailyIncome values ('JOHNS', 'SAT', 800)

insert into DailyIncome values ('SPIKE', 'TUE', 100)

insert into DailyIncome values ('SPIKE', 'THU', 300)

insert into DailyIncome values ('FREDS', 'WED', 500)

insert into DailyIncome values ('SPIKE', 'SAT', 100)

insert into DailyIncome values ('FREDS', 'SAT', 500)

insert into DailyIncome values ('FREDS', 'THU', 800)

insert into DailyIncome values ('JOHNS', 'TUE', 600)

让我们先来看看前十行数据:

select top 10 * from DailyIncome

如图所示:

DailyIncome

虽然数据是能够完全给展示了,但好像一眼望去不能得到对我们用处更大的信息,比如说我们想得到每个供应商的每天的总收入,这时我们应该做一些数据形式的转变了,平常的所用的是这样的。

select VendorId ,

sum(case when IncomeDay='MoN' then IncomeAmount else 0 end) MON,

sum(case when IncomeDay='TUE' then IncomeAmount else 0 end) TUE,

sum(case when IncomeDay='WED' then IncomeAmount else 0 end) WED,

sum(case when IncomeDay='THU' then IncomeAmount else 0 end) THU,

sum(case when IncomeDay='FRI' then IncomeAmount else 0 end) FRI,

sum(case when IncomeDay='SAT' then IncomeAmount else 0 end) SAT,

sum(case when IncomeDay='SUN' then IncomeAmount else 0 end) SUN

from DailyIncome group by VendorId

得到如下的结果:

case when结果

如果大家仔细看结果的话,会有这样的发现,这是把VendorID进行了分组,并且对于每组中IncomeDay这一列中的值都变成了新的列名字,然后对IncomeAmount进行求和操作。

这样写可能是有些麻烦,别着急,我们用Pivot函数进行行转列试下。

select * from DailyIncome ----第一步

pivot

(

sum (IncomeAmount) ----第三步

for IncomeDay in ([MON],[TUE],[WED],[THU],[FRI],[SAT],[SUN]) ---第二步

) as AvgIncomePerDay

来解释下,要想用好Pivot函数,应该理解代码注释中的这几步。

第一步:肯定是要明白数据源了,这里是DailyIncome

第二步:要明白要想让哪一列的值做新的列名字

第三步:要明白对于这新的列要求那些值呢?

下面有个练习题目,做之前不要看答案啊

问:对于SPIKE这家供应商来说,每天最大的入账金额。

select * from DailyIncome

pivot (max (IncomeAmount) for IncomeDay in ([MON],[TUE],[WED],[THU],[FRI],[SAT],[SUN])) as MaxIncomePerDay

where VendorId in ('SPIKE')

参考链接如下:

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。

oracle行转列pivot使用详解,SQL基础教程之行转列Pivot函数相关推荐

  1. python雷达图详解_Python基础教程 - matplotlib实现雷达图和柱状图

    原标题:Python基础教程 - matplotlib实现雷达图和柱状图 Python基础教程记录 - 使用matplotlib实现雷达图和柱状图. 注:主要是设置add_subplot(133),分 ...

  2. Notion使用详解一基础教程

    目录 Notion 使用详解:来自未来的笔记协作工具 Notion:All in One 的协作平台 Pages:兼任笔记和笔记本 无限层级 美观为先 分享权限 你需要掌握这些快捷键: Block E ...

  3. list对oracle结果集排序了_详解SQL窗口函数和分组排序函数

    Mysql从8.0版本开始,也和Sql Server.Oracle一样支持在查询中使用窗口函数,本文将根据官方文档,通过实例介绍窗口函数并举例分组排序函数的使用. 英语好的大佬请移步官方文档~点我! ...

  4. 【算法】棋盘覆盖详解,基础教程~

    棋盘覆盖分析与实现 一.什么是棋盘覆盖? 在一个 2^k * 2^k 个方格组成的棋盘中,若恰有一个方格与其他方格不同,则称该方格为一个特殊方格,且称该棋盘为一个特殊棋盘.显然,特殊方格在棋盘上出现的 ...

  5. python自定义函数详解_python基础教程之自定义函数介绍

    函数最重要的目的是方便我们重复使用相同的一段程序. 将一些操作隶属于一个函数,以后你想实现相同的操作的时候,只用调用函数名就可以,而不需要重复敲所有的语句. 函数的定义 首先,我们要定义一个函数, 以 ...

  6. python变量详解_python基础教程-03-变量详解

    变量就像一个小罐子,里面是存放着各种数据类型的数据,并且在程序运行过程中会发生变化.变量名在一个工作空间内是唯一的,通过变量的名字就能找到对应的数据. 变量的赋值 变量的赋值就可以理解为往小罐子里存放 ...

  7. 计算机领域 容器概念,容器技术概念详解 - Docker 基础教程

    在前面的章节里,我们安装了 Linux,也安装了 Docker,接下来是不是该上手 Docker 的使用了呢? 先不要着急,通过<Docker简介>的章节介绍,相信我们已经对 Docker ...

  8. Oracle中序列(Sequence)详解

    Oracle中序列(Sequence)详解 一 序列定义 序列(SEQUENCE)是序列号生成器,可以为表中的行自动生成序列号,产生一组等间隔的数值(类型为数字).不占用磁盘空间,占用内存. 其主要用 ...

  9. 创建emp表 oracle,Oracle中创建和管理表详解

    Oracle中创建和管理表详解 更新时间:2013年08月01日 15:44:16   作者: 以下是对Oracle中的创建和管理表进行了详细的分析介绍,需要的朋友可以过来参考下 SQL> /* ...

最新文章

  1. java员工实体模型_Java持久性、db实体与其他模型之间的通信
  2. web.xml 中的listener、 filter、servlet 加载顺序及其详解(转)
  3. c# 学习笔记 (3) 窗体单例模式
  4. 使用supervisor启动hbase
  5. solidity payable_以太坊区块链搭建与使用(五)-智能合约Solidity
  6. 实践单元测试-Using NUnit 大纲
  7. Redis连接的客户端(connected_clients)数过高或者不减的问题解决方案
  8. keras提取模型中的某一层_Keras做图片分类(四):迁移学习--猫狗大战实战
  9. Prism初研究之使用Prism 5.0开发模块化应用
  10. EVE-NG之dynamips镜像重新计算idle值
  11. python文件写入方式_Python写入文件的方式
  12. 【C++设计模式】Singleton 单例设计模式与线程安全
  13. 学大伟业:2019年数学竞赛学习经验分享
  14. QT:黑白棋的吃子规则(七)
  15. 【ELM预测】探路者算法优化极限学习机预测(含前后对比)【含Matlab源码 2204期】
  16. S29GL128P Norflash驱动读写分析
  17. 网络攻击图系统的设计与实现 文档+PPT+代码程序
  18. 阿里巴巴CEO张勇内部讲话:好的企业文化,要视人为人
  19. Maya场景渲染(一)
  20. 无人机航测作业流程,你会几个?

热门文章

  1. 乐视手机2016年要卖1500万台,能火中取栗吗?
  2. R语言提取PDF表格数据#简单!!!
  3. ASUS华硕天选3笔记本电脑FA507RM6800原装出厂Windows11系统恢复原厂OEM系统
  4. 手机相册功能,支持多选,选中列表以及选中状态,简洁
  5. 数字IC设计流程(1)
  6. 区位码查询系统(vbscript)
  7. homepod怎么设置为中文_苹果HomePod增加支持更多新功能与Siri语言!
  8. 非线性振动 matlab,数学与非线性科学 - 声振论坛 - 振动,动力学,声学,信号处理,故障诊断 - Powered by Discuz!...
  9. Web调用安卓,苹果手机摄像头,本地图片和文件
  10. oracle看一条sql的trace,SQL_TRACE和10046事件详解