美文网首页
oracle行转列

oracle行转列

作者: sleepySnail | 来源:发表于2017-08-20 12:54 被阅读0次

一、PIVOT实例

1. 建表

建立一个销售情况表,其中,year字段表示年份,quarter字段表示季度,amount字段表示销售额。quarter字段分别用Q1, Q2, Q3, Q4表示一、二、三、四季度。

CREATE TABLE SalesByQuarter

(    year INT,    -- 年份

quarter CHAR(2),  -- 季度

amount MONEY  -- 总额

)

2. 填入表数据

使用如下程序填入表数据。

SET NOCOUNT ON

DECLARE @index INT

DECLARE @q INT

SET @index = 0

DECLARE @year INT

while (@index < 30)

BEGIN

SET @year = 2005 + (@index % 4)

SET @q = (CAST((RAND() * 500) AS INT) % 4) + 1

INSERT INTO SalesByQuarter VALUES (@year, 'Q' + CAST(@q AS CHAR(1)), RAND() * 10000.00)

SET @index = @index + 1

END

3、如果我们要比较每年中各季度的销售状况,要怎么办呢?有以下两种方法:

(1)、使用传统Select的CASE语句查询

在SQL Server以前的版本里,将行级数据转换为列级数据就要用到一系列CASE语句和聚合查询。虽然这种方式让开发人员具有了对所返回数据进行高度控制的能力,但是编写出这些查询是一件很麻烦的事情。

SELECT year as 年份

, sum (case when quarter = 'Q1' then amount else 0 end) 一季度

, sum (case when quarter = 'Q2' then amount else 0 end) 二季度

, sum (case when quarter = 'Q3' then amount else 0 end) 三季度

, sum (case when quarter = 'Q4' then amount else 0 end) 四季度

FROM SalesByQuarter GROUP BY year ORDER BY year DESC

(2)、使用PIVOT

由于SQL Server 2005有了新的PIVOT运算符,就不再需要CASE语句和GROUP BY语句了。(每个PIVOT查询都涉及某种类型的聚合,因此你可以忽略GROUP BY语句。)PIVOT运算符让我们能够利用CASE语句查询实现相同的功能,但是你可以用更少的代码就实现,而且看起来更漂亮。

select * from (SELECT year, QUARTER, AMOUNT FROM SalesByQuarter) 

PIVOT (count (AMOUNT) FOR QUARTER IN ('Q1' as Q1, 'Q2' as Q2, 'Q3' as Q3, 'Q4' as Q4) ) GROUP BY YEAR;

相关文章

  • sql中列转行unpivot、行转列pivot详细讲解||Mys

    目录:一、sqlserver列转行、行转列详解二、Oracle列转行、行转列详解三、DB2列转行、行转列详解四、M...

  • Oracle 行转列

    行转列,以, 分隔 将行转列语句提取成一个Function

  • oracle行转列

    一、PIVOT实例 1. 建表 建立一个销售情况表,其中,year字段表示年份,quarter字段表示季度,amo...

  • 【oracle】行转列

  • Oracle 行转列实例

    表结构和数据 行转列样式 /*姓名 语文 数学 英语王五 89 56 89*/ 方法一 ...

  • ORACLE11 行转列

    例如需要将以下左图存储的数据 查询显示为 右图存储的数据: 以下是测试数据的准备SQL: 第一种实现方式:(利用M...

  • oracle聚合查询行转列

    表为消费流水表 关键字段mdid,viptype,je,jzrq 需求统计按各门店,各月份,所有会员以及三种不同会...

  • Oracle 行转列实例二

    上篇文章在行转列时给出了两种方法,现在给出另外的两种方法。https://www.jianshu.com/p/76...

  • oracle行转列专题(六)

    中国移动sql面试题:create table test(id number(10) primary key,ty...

  • SQL Server行转列

    SQL行转列 经典实例 创建表格 SQL行转列 经典实例 创建表格 行转列 结果 参考链接

网友评论

      本文标题:oracle行转列

      本文链接:https://www.haomeiwen.com/subject/yzrfdxtx.html