oracle中的PIVOT函数

在Oracle数据库中,PIVOT 是一个强大的功能,可以将行数据转换为列数据。这在报表和数据分析中非常有用。

基本的 PIVOT 语法如下:

SELECT *
FROM (
  SELECT <column1>, <column2>, ..., <pivot_column>, <aggregate_function>(<value_column>)
  FROM <table>
)
PIVOT (
  <aggregate_function>(<value_column>)
  FOR <pivot_column>
  IN (<pivot_value1> AS <alias1>, <pivot_value2> AS <alias2>, ...)
);
  • <column1>, <column2>, ...:这些是你想要在结果集中保留的列。
  • <pivot_column>:这是你想要作为新列标题的列。
  • <aggregate_function>(<value_column>):这是一个聚合函数(如 SUM, AVG, MAX, MIN 等),它将应用于每个 <pivot_column> 值。
  • <table>:这是包含要转换的数据的表。
  • <aggregate_function>(<value_column>)(在 PIVOT 关键字之后):这是与外部查询中的相同聚合函数。
  • <pivot_value1>, <pivot_value2>, ...:这些是 <pivot_column> 中的不同值,它们将成为新列的标题。
  • <alias1>, <alias2>, ...:这些是新列的别名。

例如,假设有一个销售表 Sales,其中包含以下数据:

Product Year Quantity
A 2018 100
B 2018 200
C 2019 300
D 2019 400

你可以使用以下查询来获取每个产品在不同年份的总销量:

SELECT *
FROM (
  SELECT Product, Year, SUM(Quantity) AS Total_Quantity
  FROM Sales
  GROUP BY Product, Year
)
PIVOT (
  SUM(Total_Quantity)
  FOR Year
  IN (2018 AS Y2018, 2019 AS Y2019)
);

这将返回以下结果:

Product Y2018 Y2019
A 100 NULL
B 200 NULL
C NULL 300
D NULL 400

相关推荐

  1. oraclePIVOT函数

    2023-12-12 06:10:04       66 阅读
  2. SQLPIVOT函数用法

    2023-12-12 06:10:04       94 阅读
  3. Oracle 函数

    2023-12-12 06:10:04       39 阅读
  4. OracleOracleLISTAGG函数

    2023-12-12 06:10:04       22 阅读
  5. MySQL替代 Oracledecode函数

    2023-12-12 06:10:04       67 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-12 06:10:04       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-12 06:10:04       106 阅读
  3. 在Django里面运行非项目文件

    2023-12-12 06:10:04       87 阅读
  4. Python语言-面向对象

    2023-12-12 06:10:04       96 阅读

热门阅读

  1. docker内更换python及pip到3.8

    2023-12-12 06:10:04       49 阅读
  2. SEO和PPC可以互相帮助的7种方式

    2023-12-12 06:10:04       55 阅读
  3. hive/spark用法记录

    2023-12-12 06:10:04       57 阅读
  4. What is MySQL Performance Schema?

    2023-12-12 06:10:04       62 阅读
  5. linux的磁盘管理

    2023-12-12 06:10:04       50 阅读
  6. 计算机网络中物理层介绍

    2023-12-12 06:10:04       57 阅读
  7. C++编程:使用boost::gil::channel_type的示例程序

    2023-12-12 06:10:04       63 阅读
  8. MATLAB中的Table数据使用

    2023-12-12 06:10:04       59 阅读
  9. 测试:接口参数测试

    2023-12-12 06:10:04       62 阅读