SELECT ROUND((current_year_total - last_year_total) / last_year_total * 100, 2) AS growth_rate FROM ( SELECT SUM(amount) AS current_year_total FROM my_table WHERE date_column BETWEEN TO_DATE('2022-01-01', 'YYYY-MM-DD') AND TO_DATE('2022-03-31', 'YYYY-MM-DD') ) c, ( SELECT SUM(amount) AS last_year_total FROM my_table WHERE date_column BETWEEN TO_DATE('2021-01-01', 'YYYY-MM-DD') AND TO_DATE('2021-03-31', 'YYYY-MM-DD') ) l;优化这段代码,里面要运用到开窗函数
时间: 2024-02-12 10:05:05 浏览: 62
以下是一个优化后的示例Oracle代码,它使用开窗函数计算同比增长率:
```
SELECT DISTINCT
ROUND((SUM(CASE WHEN EXTRACT(YEAR FROM date_column) = 2022 THEN amount END) OVER () - SUM(CASE WHEN EXTRACT(YEAR FROM date_column) = 2021 THEN amount END) OVER ()) / SUM(CASE WHEN EXTRACT(YEAR FROM date_column) = 2021 THEN amount END) OVER () * 100, 2) AS growth_rate
FROM my_table
WHERE EXTRACT(MONTH FROM date_column) BETWEEN 1 AND 3;
```
在上面的示例中,我们使用SUM()函数和CASE语句来计算2022年1月至3月和去年同期的数据总和,并使用开窗函数将结果存储在临时表中。然后,我们使用这些值计算同比增长率,并使用ROUND函数将其保留为两个小数位。我们还使用DISTINCT关键字来确保查询只返回一个结果。请注意,我们使用EXTRACT函数来从date_column列中提取年份和月份,并使用WHERE子句来限制查询仅返回1月至3月的数据。
阅读全文