Pivot函数在Oracle数据库中用于将行数据转换为列数据,从而使数据更易于分析和查看
- 多个聚合函数:在Oracle 19c及更高版本中,您可以在一个PIVOT子句中使用多个聚合函数。这使得在一个查询中对多个列执行不同类型的聚合操作变得更加容易。
示例:
SELECT * FROM sales_data PIVOT ( SUM(sales) AS total_sales, AVG(profit) AS avg_profit FOR product_id IN (1001 AS 'Product A', 1002 AS 'Product B') );
- 动态列:在Oracle 19c及更高版本中,您可以使用动态列功能自动生成PIVOT子句中的列名。这样,您无需事先知道所有可能的列名,查询仍然可以正常工作。
示例:
DECLARE v_cols CLOB; BEGIN SELECT LISTAGG('''' || product_name || ''' AS "' || product_name || '"', ', ') WITHIN GROUP (ORDER BY product_name) INTO v_cols FROM (SELECT DISTINCT product_name FROM sales_data); EXECUTE IMMEDIATE ' SELECT * FROM sales_data PIVOT ( SUM(sales) AS total_sales, AVG(profit) AS avg_profit FOR product_name IN (' || v_cols || ') )'; END; /
- 使用JSON格式输出:在Oracle 21c及更高版本中,您可以使用PIVOT JSON子句将结果以JSON格式返回。这使得在处理具有大量列或动态列的数据时更加灵活。
示例:
SELECT * FROM sales_data PIVOT JSON ( SUM(sales) AS total_sales, AVG(profit) AS avg_profit FOR product_id IN (1001 AS 'Product A', 1002 AS 'Product B') );
请注意,上述示例中的SQL语法可能因您使用的Oracle数据库版本而有所不同。在使用这些新特性之前,请确保您的数据库版本支持它们。