Oracle unpivot 函数怎样将列转行

avatar
作者
猴君
阅读量:0

在Oracle中,可以使用UNPIVOT操作将多个列转换为行

SELECT * FROM your_table UNPIVOT (   value -- 这是新生成的值列的名称   FOR column_name -- 这是新生成的列名列的名称   IN (column1 AS 'Column1', column2 AS 'Column2', column3 AS 'Column3') -- 这里列出你想要转换为行的列名 ); 

这里是一个具体的例子。假设我们有一个销售表(sales_data),包含以下列:product_id, sales_q1, sales_q2, sales_q3。我们想要将每个季度的销售额(sales_q1、sales_q2和sales_q3)转换为行。

SELECT product_id, quarter, sales FROM sales_data UNPIVOT (   sales   FOR quarter   IN (sales_q1 AS 'Q1', sales_q2 AS 'Q2', sales_q3 AS 'Q3') ); 

执行此查询后,结果集将显示每个产品在每个季度的销售额,其中每个季度的销售额都显示为一行。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!